Git合并分支的两种常用方式`git merge`和`git cherry-pick`

Git合并分支的两种常用方式`git merge`和`git cherry-pick`

写在前面

复制代码
一般我们使用git合并分支常用的就是`git merge`和`git cherry-pick`这两种方式。
它们都是 Git 中用于整合代码变更的命令,但它们的使用场景和工作方式有所不同。
`git merge`是合并整个分支的所有提交,当两个分支差异比较大的时候不适合将整个分支合并过去,
这时候就需要使用`git cherry-pick`(优选) 选择我们需要的提交记录进行合并。
下面介绍一下二者的使用方式和应用场景。

1. git merge

用途

git merge主要用于将一个分支的所有更改合并到另一个分支。通常在开发过程中,当你在一个特性分支上完成了开发工作,想要将这些更改集成到主分支(如main或master)时,就会使用git merge

工作方式

它会将源分支上的所有提交历史合并到目标分支。如果在合并过程中没有冲突,Git 会创建一个新的合并提交,该提交包含两个分支的更改;如果有冲突,则需要手动解决冲突后再完成合并。

使用git命令方式合并

复制代码
# 切换到目标分支
git checkout main
# 合并特性分支到主分支
git merge feature-branch

使用idea工具方式合并

1、准备工作

确保你已经在 IDEA 中正确配置了 Git,并且项目已经与 Git 仓库关联。可以通过 File -> Settings(Windows/Linux)或 IntelliJ IDEA -> Preferences(Mac),在 Version Control -> Git 中查看和配置 Git 路径。

打开你要操作的项目,确保当前分支是你想要将提交合并到的目标分支。

2、具体操作

通过版本控制 (Version Control) 工具窗口,通常可以通过点击 IDEA 左下角的 Git 图标打开。

2. git cherry-pick

用途

git cherry-pick允许你从一个或多个提交中选择特定的更改,并将这些更改应用到当前分支。当你只需要某个分支上的部分提交,而不是整个分支的所有更改时,就可以使用git cherry-pick

工作方式

它会将指定提交的更改复制到当前分支,并创建一个新的提交。这个新提交的内容与原始提交相同,但提交哈希值不同。如果在应用更改时出现冲突,同样需要手动解决冲突后再完成操作。

使用git命令方式合并

复制代码
# 切换到目标分支
git checkout main
# 应用指定提交的更改到当前分支
git cherry-pick <commit-hash>

使用idea工具方式合并

准备工作git merge相同,点击 IDEA 左下角的 Git 图标打开操作窗口。

3. 区别总结

范围git merge是合并整个分支的所有提交,而git cherry-pick只选择特定的提交进行应用。
提交历史git merge会保留源分支的提交历史,形成一个合并提交;git cherry-pick会创建新的提交,原始提交历史仍然保留在源分支上。
使用场景 :当你需要将一个分支的完整开发成果集成到另一个分支时,使用git merge;当你只需要某个分支上的部分提交时,使用git cherry-pick

最后,一般在git merge合并操作能满足使用需求的情况下,优先建议使用 git merge,而不是git cherry-pick。只有两个分支存在冲突时,才建议使用git cherry-pick

相关推荐
AA陈超2 小时前
Git常用命令大全及使用指南
笔记·git·学习
无限进步_2 小时前
C语言数组元素删除算法详解:从基础实现到性能优化
c语言·开发语言·windows·git·算法·github·visual studio
松涛和鸣2 小时前
16、C 语言高级指针与结构体
linux·c语言·开发语言·数据结构·git·算法
楠语2 小时前
从指针行为理解Git中的reset操作
git
扛麻袋的少年5 小时前
git reset 和 git reflog 解决代码分支提交错误
git
放学有种别跑、7 小时前
GIT使用指南
大数据·linux·git·elasticsearch
雨雨雨雨雨别下啦7 小时前
【从0开始学前端】 Git版本控制系统
前端·git
happyCoder8 小时前
VS Code Git 神器:内置功能与GitLens插件使用技巧
git·github
小番茄夫斯基8 小时前
深入解析 git merge 和 git rebase 的区别
git
不会写程序的未来程序员8 小时前
详细的 Git 操作分步指南
大数据·git·elasticsearch