要使用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/讲解。