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会将你的代码恢复到操作前的状态。
相关推荐
花木偶1 分钟前
【郑大二年级信安小学期】Day9:XSS跨站攻击&XSS绕过&CSRF漏洞&SSRF漏洞
前端·xss
FogLetter2 分钟前
节流(Throttle):给频繁触发的事件装上"冷却时间"
前端·javascript
小公主4 分钟前
彻底搞懂 Event Loop!这篇文章帮你一次性吃透宏任务、微任务、执行顺序
前端·javascript
xiaominlaopodaren8 分钟前
爱心动画的数学之美:从心形曲线到粒子系统
前端
AI悦创Python辅导24 分钟前
如何挑选适合项目场景的数据分析工具?
前端
用户92724725021927 分钟前
新闻自动采集并通过API发布到博客
前端·后端
清风920031 分钟前
Logback——日志技术(基础)
java·前端·logback
EndingCoder31 分钟前
排序算法与前端交互优化
开发语言·前端·javascript·算法·排序算法·交互
三月的一天1 小时前
在 React Three Fiber 中实现 3D 模型点击扩散波效果
前端·react.js·前端框架
爱敲代码的小冰1 小时前
npm 切换 node 版本 和npm的源
前端·npm·node.js