解决冲突
现在我把gitTest中的东西全删了包括那个.git文件。
初始化仓库git init,新建一个a.txt,在里边写个master,执行git add a.txt,然后执行git commit -m ‘add a.txt’
然后创建第一个分支 git branch feature1,然后创建第二个分支并切换到第二个分支git checkout -b feature2,在a.txt中另起一行添加feature2,然后执行git add a.txt和 git commit -m ‘feature2 add a word’,然后切换到master,git checkout master,把feature2分支合并到master分支, git merge –no-ff -m ‘merge feature2’ feature2。之后切换到feature1,git checkout feature1,在a.txt中另起一行添加feature1,然后执行git add a.txt和 git commit -m ‘feature1 add a word’。
现在整理一下,master分支a.txt中原始的数据为
master
- 1
后来创建了分支feature1里边的内容同样为
master
- 1
- 2
后来创建了feature2分支,并把feature2中的内容合并到了master,所以现在master中a.txt的内容为
master
feature2
- 1
- 2
- 3
后来我把feature1中的信息改为
master
feature1
- 1
- 2
- 3
现在master中的内容和feature1最初复制的内容不一样,现在切换到master分支,把feature1合并到master肯定会有冲突。
执行git merge feature1
$ git merge --no-ff -m 'merge feature1' feature1
Auto-merging a.txt
CONFLICT (content): Merge conflict in a.txt
Automatic merge failed; fix conflicts and then commit the result.
- 1
- 2
- 3
- 4
- 5
会发现有冲突了,这时候a.txt中的内容为
master
<<<<<<< HEAD
feature2
=======
feature1
>>>>>>> feature1
- 1
- 2
- 3
- 4
- 5
- 6
- 7
Git用<<<<<<<
,=======
,>>>>>>>
标记出不同分支的内容。HEAD为当前所在分支的内容,也就是说现在master中的内容。feature1为feature1分支中的内容。
现在我a.txt中内容改为
master
feature2
feature1
- 1
- 2
- 3
- 4
然后执行
YZ@YZ MINGW64 /d/gitTest (master|MERGING)
$ git add a.txt
YZ@YZ MINGW64 /d/gitTest (master|MERGING)
$ git commit -m 'fix confict'
[master 6f57951] fix confict
YZ@YZ MINGW64 /d/gitTest (master)
$
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
这样就好了。git log –graph –pretty=oneline –abbrev-commit
–pretty=oneline这个参数的目的是不再显示Author和Date,只显示带有id号的一行。–abbrev-commit的意思是缩写id号。
YZ@YZ MINGW64 /d/gitTest (master)
$ git log --graph --pretty=oneline --abbrev-commit
* 7f2f3b5 (HEAD -> master) fix conflict
|\
| * f56a04d (feature1) feature1 add a word
* | 1387cb8 Merge branch 'feature2'
|\ \
| |/
|/|
| * 14ef937 (feature2) feature2 add a word
|/
* cf361f6 add a.txt
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
要修改上一条提交信息,可以使用git commit –amend命令。上一条的提交信息为fix config,但它其实是feature1分支的合并,解决合并时发生的冲突只是过程之一,这样标记是在不妥。于是,我们修改这条提交信息。
$ git commit -m 'merge feature1' --amend
[master dea2e9d] merge feature1
Date: Sun Aug 27 21:24:11 2017 +0800
- 1
- 2
- 3
- 4
再次查看日志,可以发现其变成了
$ git log --graph --pretty=oneline --abbrev-commit
* dea2e9d (HEAD -> master) merge feature1
|\
| * f56a04d (feature1) feature1 add a word
* | 1387cb8 Merge branch 'feature2'
|\ \
| |/
|/|
| * 14ef937 (feature2) feature2 add a word
|/
* cf361f6 add a.txt