一、 git merge
使用:
js
// 切换到当前分支
git checkout test
// 合并目标分支
git merge master
merge操作会将master分支的最新提交E与test分支的最新提交C D与两者的公共祖先B进行三方合并生成最新提交G。
特点:
1.merge会将目标分支与当前分支的最新提交进行合并,如果没有遇到冲突的情况下会生成一个新的提交记录并默认进行提交。
2.merge注重的是真实的提交历史记录,保持树状的提交历史。
遇到冲突如何解决:
- 解决冲突 :首先,手动编辑冲突的文件。冲突部分通常会被特殊的标记包围,比如
<<<<<<<
,=======
和>>>>>>>
。你需要检查这些部分,决定保留哪些更改,并删除这些标记和你不想要的更改。 - 将解决冲突后的文件添加到暂存区 :使用
git add
命令将解决冲突后的文件添加到暂存区。可以逐个添加文件,也可以使用git add .
一次性添加所有已解决冲突的文件。 - 提交合并后的代码 :使用
git commit
命令提交合并后的代码。在提交时,最好附上一个有意义的提交信息,说明此次合并的内容和解决冲突的情况,例如git commit -m "Merge branch 'feature' into 'main' with conflict resolution"
。 - 推送合并后的代码 :最后,使用
git push
命令将合并后的代码推送到远程仓库。
因此merge再遇到冲突时需要手动解决冲突并提交,不会进行自动提交。
二、git rebase
js
git checkout test(待变基分支)
git rebase master(基分支)
特点:
- git rebase在没有冲突的情况下不会自动提交。当执行 rebase 操作时,git 会从两个分支的共同祖先开始提取待变基分支上的修改,然后将待变基分支指向基分支的最新提交,最后将刚才提取的修改应用到基分支的最新提交的后面,这个过程本身并不包括提交操作。
- git rebase会改变当前分支的基底,使分支记录呈线性。
遇到冲突如何解决:
- 解决冲突 :首先,你需要手动编辑文件以解决冲突。冲突的部分通常会被特殊的标记包围,比如
<<<<<<<
,=======
和>>>>>>>
。你需要保留你想要的更改,并删除这些标记和你不想要的更改。 - 添加文件到暂存区 :一旦冲突解决,你需要使用
git add
命令将修改后的文件添加到暂存区。你可以逐个添加文件,或者使用git add .
来添加所有修改过的文件。 - 继续rebase :接下来,使用
git rebase --continue
命令来继续rebase过程。这个命令会应用你之前解决的冲突,并尝试继续将剩下的提交去进行对比。 - 处理可能的后续冲突:如果在继续rebase的过程中遇到更多的冲突,你需要重复上述步骤(解决冲突、添加文件、继续rebase)直到所有的冲突都被解决。
- 完成rebase:如果rebase过程顺利完成,没有更多的冲突需要解决,那么你的分支现在应该已经包含了所有你想要的提交,并且是基于最新的上游分支。
- commit提交:当完成rebase之后,需要手动进行提交操作,然后push到远程仓库
需要注意的是,在使用rebase时,如果当前分支已经提交到了远程仓库中,那么再git push
时会出现问题:
原因就是因为使用了rebase导致跟远程分支的历史提交记录发生了偏离,因此需要git push -f
进行强制push,这一操作也会使远程分支的提交记录发生改变。
三、git cherry-pick
js
git checkout 当前分支
git cherry-pick <commit-hash>...
特点:
1.git cherry-pick
可以选择一个或多个已经存在的提交,并应用到当前分支,如果没有遇到冲突,会再当前分支的历史记录后边新增一个或多个提交记录,没有冲突情况下也会默认进行提交。
2.与git merge
不同,git merge
会把两个分支的提交记录进行合并后新增一个新的提交记录,而git cherry-pick
只会再当前分支后新增,不会进行合并。
遇到冲突如何解决:
- 解决冲突 :首先,你需要手动编辑文件以解决冲突。冲突的部分通常会被特殊的标记包围,比如
<<<<<<<
,=======
和>>>>>>>
。你需要保留你想要的更改,并删除这些标记和你不想要的更改。 - 将解决冲突后的文件添加到暂存区 :使用
git add
命令将解决冲突后的文件添加到暂存区。可以逐个添加文件,也可以使用git add .
一次性添加所有已解决冲突的文件。 - 继续cherry-pick :一旦冲突解决并添加了文件,使用
git cherry-pick --continue
命令来继续cherry-pick操作。这个命令会应用你之前解决的冲突,并尝试继续cherry-pick操作。 - 处理可能的后续冲突:如果在继续cherry-pick的过程中遇到更多的冲突,你需要重复上述步骤(解决冲突、添加文件、继续cherry-pick)直到所有的冲突都被解决。
- 放弃cherry-pick :如果由于某些原因你决定放弃cherry-pick操作,可以使用
git cherry-pick --abort
命令来中止操作,此时Git会将你的代码恢复到操作前的状态。