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

相关推荐
Ac157ol3 小时前
2025年最新版 Git和Github的绑定方法,以及通过Git提交文件至Github的具体流程(详细版)
git·elasticsearch·github
沐风ya3 小时前
git -- 对远程仓库的操作 -- 查看,添加(与clone对比),抓取和拉取,推送(注意点,抓取更新+合并的三种方法,解决冲突,对比),移除
git
spencer_tseng4 小时前
IntelliJ IDEA clean git password
java·git·eclipse·intellij-idea
Pigwantofly7 小时前
Git命令归纳
git
Fishermen_sail8 小时前
如何写 commit message?
git·github
程序猿chen9 小时前
《JVM考古现场(二十三):归零者·重启奇点的终极奥义》
java·jvm·git·后端·程序人生·java-ee·改行学it
半个脑袋儿9 小时前
Git提交修正的核心技巧:git commit --amend 的专业实践与深度解析
git·gitlab
程序猿chen2 天前
JVM考古现场(二十二):降维打击·用二向箔优化内存模型
java·jvm·git·后端·面试·java-ee·跳槽
汤永红2 天前
windows下git bash安装SDKMan报错Looking for unzip...Not found
java·git·sdkman