Webcourse/00-前端工具/01-Git的使用.md
2018-06-11 21:11:23 +08:00

5.0 KiB
Raw Blame History

常见操作

配置用户信息

git config --global user.name "smyhvae"

git config --global user.email "smyhvae@163.com"

分支的合并

场景基于master分支的代码开发一个新的特性

如果你直接在master分支上开发这个新特性是不好的万一你在开发特性1的时候,领导突然又要叫你去开发特性2就不好处理了。难道开发的两个特性都提交到master一会儿提交特性1的commit一会儿提交特性2的commit这会导致commit记录很混乱。

所以,我给你的建议做法是:给每个特性都单独建一个的新的分支。

比如说,我专门给特性1建一个分支feature_item_recommend。具体做法如下:

1基于master分支创建一个新的分支起名为feature_item_recommend

$ git checkout -b feature_item_recommend

Switched to a new branch 'feature_item_recommend'

上面这行命令,相当于:

$ git branch feature_item_recommend    // 创建新的分支

$ git checkout feature_item_recommend  //切换到新的分支

2在新的分支feature_item_recommend上,完成开发工作,并 commit 、push。

3将分支feature_item_recommend上的开发进度合并到master分支

$ git checkout master  //切换到master分支

$ git merge feature_item_recommend    //将分支 feature_item_recommend 的开发进度合并到 master 分支

合并之后,master分支和feature_item_recommend分支会指向同一个位置。

3删除分支feature_item_recommend

既然 特性1 开发完了也放心地提交到master了那我们就可以将这个分支删除了。

git branch -d feature_item_recommend

注意,我们当前是处于master分支的位置,来删除feature_item_recommend分支。如果当前是处于feature_item_recommend分支,是没办法删除它自己的。

同理,当我转身去开发特性2的时候,也是采用同样的步骤。

合并分支时,如果存在分叉

20180610_1650.png

比如说上面这张图中最早的时候master分支是位于C2节点。我基于C2节点new出一个新的分支iss53,我在iss53上提交了好几个commit。

现在,我准备把iss53上的几个commit合并到master上此时发现master分支已经前进到C4了。那该怎么合并呢

合并的命令仍然是:

$ git checkout master

$ git merge iss53

解释

这次合并的实现,并不同于简单的并入方式。这一次,我的开发历史是从更早的地方开始分叉的。

由于当前 master 分支所指向的commit (C4)并非想要并入分支iss53的直接祖先Git 不得不进行一些处理。就此例而言Git 会用两个分支的末端C4 和C5和它们的共同祖先C2进行一次简单的三方合并计算。

Git 没有简单地把分支指针右移而是对三方合并的结果作一新的快照并自动创建一个指向它的commitC6如下图所示。我们把这个特殊的commit 称作合并提交mergecommit因为它的祖先不止一个。

值得一提的是Git 可以自己裁决哪个共同祖先才是最佳合并基础这和CVS 或Subversion1.5 以后的版本不同它们需要开发者手工指定合并基础。所以此特性让Git 的合并操作比其他系统都要简单不少。

20180610_1710.png

解决合并时发生的冲突

20180610_1740.png

如果 feature1和feature2修改的是同一个文件中代码的同一个位置那么把feature1合并到feature2时就会产生冲突。这个冲突需要人工解决。步骤如下

1手动修改文件手动修改冲突的那个文件决定到底要用哪个分支的代码。

2git add解决好冲突后输入git status,会提示Unmerged paths。这个时候,输入git add即可,表示:修改冲突成功,加入暂存区

3git commit 提交。

然后,我们可以继续把 feature1 分支合并到 master分支最后删除feature1、feature2。

注意两个分支的同一个文件的不同地方合并时git会自动合并不会产生冲突。

比如分支feture1对index.html原来的第二行之前加入了一段代码。 分支feature2对index.html在原来的最后一行的后面加入了一段代码。 这个时候在对两个分支合并git不会产生冲突因为两个分支是修改同一文件的不同位置。 git自动合并成功。不管是git自动合并成功还是在人工解决冲突下合并成功提交之前都要对代码进行测试。

日常操作积累

修改已经commit的备注信息

branch1的某个commit1合并到branch2当中

切换到branch2中然后执行如下命令

git cherry-pick commit1

推荐书籍

  • 《pro.git中文版》

推荐连接

2018-06