git merge,rebase,cherry-pick区别以及遇到冲突之后如何解决

一、 git merge

使用:

js 复制代码
// 切换到当前分支
git checkout test
// 合并目标分支
git merge master

merge操作会将master分支的最新提交E与test分支的最新提交C D与两者的公共祖先B进行三方合并生成最新提交G。

特点:

1.merge会将目标分支与当前分支的最新提交进行合并,如果没有遇到冲突的情况下会生成一个新的提交记录并默认进行提交。

2.merge注重的是真实的提交历史记录,保持树状的提交历史。

遇到冲突如何解决:

  1. 解决冲突 :首先,手动编辑冲突的文件。冲突部分通常会被特殊的标记包围,比如<<<<<<<=======>>>>>>>。你需要检查这些部分,决定保留哪些更改,并删除这些标记和你不想要的更改。
  2. 将解决冲突后的文件添加到暂存区 :使用git add命令将解决冲突后的文件添加到暂存区。可以逐个添加文件,也可以使用git add .一次性添加所有已解决冲突的文件。
  3. 提交合并后的代码 :使用git commit命令提交合并后的代码。在提交时,最好附上一个有意义的提交信息,说明此次合并的内容和解决冲突的情况,例如git commit -m "Merge branch 'feature' into 'main' with conflict resolution"
  4. 推送合并后的代码 :最后,使用git push命令将合并后的代码推送到远程仓库。

因此merge再遇到冲突时需要手动解决冲突并提交,不会进行自动提交。

二、git rebase

js 复制代码
git checkout test(待变基分支)
git rebase master(基分支)

特点:

  1. git rebase在没有冲突的情况下不会自动提交。当执行 rebase 操作时,git 会从两个分支的共同祖先开始提取待变基分支上的修改,然后将待变基分支指向基分支的最新提交,最后将刚才提取的修改应用到基分支的最新提交的后面,这个过程本身并不包括提交操作。
  2. git rebase会改变当前分支的基底,使分支记录呈线性。

遇到冲突如何解决:

  1. 解决冲突 :首先,你需要手动编辑文件以解决冲突。冲突的部分通常会被特殊的标记包围,比如<<<<<<<=======>>>>>>>。你需要保留你想要的更改,并删除这些标记和你不想要的更改。
  2. 添加文件到暂存区 :一旦冲突解决,你需要使用git add命令将修改后的文件添加到暂存区。你可以逐个添加文件,或者使用git add .来添加所有修改过的文件。
  3. 继续rebase :接下来,使用git rebase --continue命令来继续rebase过程。这个命令会应用你之前解决的冲突,并尝试继续将剩下的提交去进行对比。
  4. 处理可能的后续冲突:如果在继续rebase的过程中遇到更多的冲突,你需要重复上述步骤(解决冲突、添加文件、继续rebase)直到所有的冲突都被解决。
  5. 完成rebase:如果rebase过程顺利完成,没有更多的冲突需要解决,那么你的分支现在应该已经包含了所有你想要的提交,并且是基于最新的上游分支。
  6. 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只会再当前分支后新增,不会进行合并。

遇到冲突如何解决:

  1. 解决冲突 :首先,你需要手动编辑文件以解决冲突。冲突的部分通常会被特殊的标记包围,比如<<<<<<<=======>>>>>>>。你需要保留你想要的更改,并删除这些标记和你不想要的更改。
  2. 将解决冲突后的文件添加到暂存区 :使用 git add 命令将解决冲突后的文件添加到暂存区。可以逐个添加文件,也可以使用 git add . 一次性添加所有已解决冲突的文件。
  3. 继续cherry-pick :一旦冲突解决并添加了文件,使用 git cherry-pick --continue 命令来继续cherry-pick操作。这个命令会应用你之前解决的冲突,并尝试继续cherry-pick操作。
  4. 处理可能的后续冲突:如果在继续cherry-pick的过程中遇到更多的冲突,你需要重复上述步骤(解决冲突、添加文件、继续cherry-pick)直到所有的冲突都被解决。
  5. 放弃cherry-pick :如果由于某些原因你决定放弃cherry-pick操作,可以使用 git cherry-pick --abort 命令来中止操作,此时Git会将你的代码恢复到操作前的状态。
相关推荐
晚霞的不甘14 分钟前
HarmonyOS ArkTS 进阶实战:深入理解边距、边框与嵌套布局
前端·计算机视觉·华为·智能手机·harmonyos
_野猪佩奇_牛马版14 分钟前
ReACT Agent 开发知识点总结
前端
牛奶26 分钟前
你发送的消息,微信到底怎么送到的?
前端·websocket·http
酉鬼女又兒31 分钟前
零基础快速入门前端DOM 元素获取方法详解:从代码到实践(可用于备赛蓝桥杯Web应用开发)
前端·javascript·职场和发展·蓝桥杯·js
牛奶31 分钟前
为什么关掉浏览器再打开,你还是登录状态?
前端·网络协议·https
bjxiaxueliang32 分钟前
一文掌握Python aiohttp:异步Web开发从入门到部署
开发语言·前端·python
Liudef0642 分钟前
从0到1开发ReAct智能体:原理、实现与最佳实践
前端·react.js·前端框架
金豆呀1 小时前
WPS自定义公式,相似度匹配
前端·javascript·wps
jiayong231 小时前
0基础学习VUE3 第 1 课:项目启动流程
前端·vue.js·学习
今天又在摸鱼1 小时前
学习vue前必要的js语法
前端·vue.js·学习