要使用GitHub功能,首先要登陆官方网站https://github.com,注册GitHub账号。

在浏览器中的操作

新建一个仓库。一个项目一旦被Git控制了版本历史,在GitHub上就有另外一个名字叫仓库

注意:GitHub上的每一个项目的名字都是在自己的用户名之下的,所以不用担心会跟其他人的项目重名,只要自己的用户名之下没有该项目即可。添加项目描述,private功能是收费的。点击创建按钮,项目就创建成功了。此时github页面跳转到https://github.com/用户名/项目名,即新创建的项目的主页。

 Commit动词表示做一个版本,名词则表示版本的意思。

很多时候代码是要在本地写的,因为本地有自己最喜欢的编辑器,有编译和调试的环境,操作起来比较高效,在本地可以通过安装Git,通过命令行操作,相对复杂,对于新手来说,可以使用图形化的客户端进行本地的相关操作。根据对应的系统去下载对应的客户端。这里以Windows客户端为例。

如果官网下载安装的速度太慢,可以参考网上的其他离线版下载安装。安装完成后登陆自己的GitHub账号,并按照向导做一些简单的配置即可。

在客户端的操作:

客户端添加项目

点击“+”,有3种方式:

Add:添加本地已经存在的项目,输入路径即可;

Create:新建一个项目,输入项目名称,选择一个保存路径即可;

Clone:把远程GitHub网站上的项目克隆到本地

以Create方式为例:

在本地编辑器中打开新建的项目,新建文件hello

返回GitHub客户端,会看到如下的变化

撤销做过的版本,点击版本列表中的版本,然后在设置中选择“Undo most recent commit”

由于是在本地新建的项目,在GitHub网站上没有该项目,所有此时是“publish”功能,当把项目发布到网站上后,此处的按钮就会变成Sync(同步)。

项目同步成功后,登录GitHub网站,可以看到图示的项目

分支

分支在底层的实现原理

一般开新分支的目的是:有新的想法需要开发新的代码,但是又不想污染到master分支上的很重要的代码。原则上是master分支上代码都应该是随时可以放到服务器上去当产品跑的代码,测试性的代码不能放在master分支上。

在客户端新建和删除分支

新创建的分支会自动作为当前分支

在master分支和new分支之间切换时会发现,本地工作目录中的文件也会发生变化,把master分支作为当前分支时,工作目录中没有good文件,切换到new分支时,工作目录中又出现了good文件。

把新分支发布到GitHub网站上之后,查看网站上的分支,结果如下。

网站上新建和删除分支

合并分支

本地仓库的master分支和远端网站上的仓库的master分支,虽然名字相同,但是处在不同的仓库之中(一个在本地的仓库,一个在远端的仓库),可以存在并行开发的情况。

 

在本地的master分支上做了新的commit

在网站上的master分支上也做了一个commit,此时客户端和远端还没有同步。

客户端和远端的修改互不影响

代码冲突

<<<<<<< HEAD

=======

>>>>>>> origin/master

称为冲突标识符。

<<<<<<<HEAD 是代表当前分支,===== 就是两个冲突代码块的分界线了,>>>>>>> origin/master代表另外一个分支,此处指远端的master分支

此处冲突的本质可以理解为时程序员的意见不统一造成的,不是Git能直接解决的问题,需要开发者之间商量,最后达成一致。解决冲突就是把上面的三行“冲突标示符”都删掉,然后修改代码,之后回到客户端,做新版本,重新合并分支。

更多详细内容请参考happypeter老师的http://gitbeijing.com/讲解。

GitHub版本控制入门(新手学习)的更多相关文章

  1. Git版本控制软件结合GitHub从入门到精通常用命令学习手册(转)

    简要参考:http://www.tuicool.com/articles/mEvaq2 http://gitref.org/zh/index.html GIT 学习手册简介 本站为 Git 学习参考手 ...

  2. 问题集录--新手入门深度学习,选择TensorFlow 好吗?

    新手入门深度学习,选择 TensorFlow 有哪些益处? 佟达:首先,对于新手来说,TensorFlow的环境配置包装得真心非常好.相较之下,安装Caffe要痛苦的多,如果还要再CUDA环境下配合O ...

  3. .NetCore微服务Surging新手傻瓜式 入门教程 学习日志---先让程序跑起来(一)

    原文:.NetCore微服务Surging新手傻瓜式 入门教程 学习日志---先让程序跑起来(一) 写下此文章只为了记录Surging微服务学习过程,并且分享给广大想学习surging的基友,方便广大 ...

  4. 适合 Go 新手学习的开源项目——在 GitHub 学编程

    作者:HelloGitHub-小鱼干&卤蛋 故事要从 2007 年说起.因为受够了 C++ 煎熬的 Google 首席软件工程师 Rob Pike 召集 Robert Griesemer 和 ...

  5. 适合 JS 新手学习的开源项目——在 GitHub 学编程

    作者:HelloGitHub-小鱼干 这里是 HelloGitHub 的<GitHub 上适合新手的开源项目>系列的最后一篇,系列文章: C++ 篇 Python 篇 Go 篇 Java ...

  6. Sql Server新手学习入门

    Sql Server新手学习入门 http://www.tudou.com/home/_117459337

  7. .NetCore微服务Surging新手傻瓜式 入门教程 学习日志---结构简介(二)

    原文:.NetCore微服务Surging新手傻瓜式 入门教程 学习日志---结构简介(二) 先上项目解决方案图: 以上可以看出项目结构可以划分为4大块,1是surging的核心底层,2,3,4都可以 ...

  8. Webpack新手入门教程(学习笔记)

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; text-align: center; font: 30.0px Helvetica; color: #000000 } ...

  9. nodeJs 5.0.0 安装配置与nodeJs入门例子学习

    新手学习笔记,高手请自动略过 安装可以先看这篇:http://blog.csdn.net/bushizhuanjia/article/details/7915017 1.首先到官网去下载exe,或者m ...

随机推荐

  1. 深入理解Java中的多态

    一.什么是多态? 多态指同一个实体同时具有多种形式.它是面向对象程序设计(OOP)的一个重要特征.如果一个语言只支持类而不支持多态,只能说明它是基于对象的,而不是面向对象的. 二.多态是如何实现的? ...

  2. ZOJ - 4082:Little Sub and his Geometry Problem (双指针)

    Little Sub loves math very much, and has just come up with an interesting problem when he is working ...

  3. vmware NAT 网络出现问题的解决方法

    nat 网络的配制: 用nat网络相对来说,以后网段出现改变,都不会有大的影响,方便以后做实验. 用dhclient 来获取IP dhclent -r 是用来关闭获取IP的. 自动获取IP,也可以改成 ...

  4. (4)django的新手三件套(返回页面、返回字符、重定向)

    from django.shortcuts import render,HttpResponse,redirect 新手三件套,前期开发都会用到 render   #向浏览器返回页面 HttpResp ...

  5. 《DSP using MATLAB》Problem 6.7

    代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ %% Output In ...

  6. 【spring源码分析】spring关于循环依赖的问题

    引言:循环依赖就是N个类中循环嵌套引用,如果在日常开发中我们用new 对象的方式发生这种循环依赖的话程序会在运行时一直循环调用,直至内存溢出报错.下面说一下Spring是如果解决循环依赖的. 第一种: ...

  7. Java定时任务调度工具Timer Quartz

      -----------------------------------Timer PS:Timer是 jdk中的:Quartz是第三方的 PS:也即是返回执行任务时候的时间 ----------- ...

  8. React中jquery引用

    安装jQuery npm i jquery -S 在那个地方使用jQuery就在什么地方引入jQuery import $ from 'jquery'

  9. <--------------------------Java继承及抽象类------------------------------>

    1 继承的好处   关键词-->extends 1.1.继承的出现提高了代码的复用性,提高软件开发效率. 1.2.继承的出现让类与类之间产生了关系,提供了多态的前提. 2 继承的注意事项 *a: ...

  10. How_Require_Extensions_Work

    Why Doing require extensions correctly is essential, because: Users should be able to install multip ...