git cherry-pick 小结

git cherry-pick可以选择某一个分支中的一个或几个commit(s)来进行操作。例如,假设我们有个稳定版本的分支,叫v2.0,另外还有个开发版本的分支v3.0,我们不能直接把两个分支合并,这样会导致稳定版本混乱,但是又想增加一个v3.0中的功能到v2.0中,这里就可以使用cherry-pick了。


就是对已经存在的commit 进行 再次提交

简单用法:

git cherry-pick <commit id>

注意:当执行完 cherry-pick 以后,将会 生成一个新的提交;这个新的提交的哈希值和原来的不同,但标识名 一样;

例如:
$ git checkout old_cc
$ git cherry-pick 38361a68    # 这个 38361a68 号码,位于:

 
$ git log
commit 38361a68138140827b31b72f8bbfd88b3705d77a
Author: Siwei Shen <siwei.shen@focusbeijing.com>
Date:   Sat Dec 10 00:09:44 2011 +0800


1. 如果顺利,就会正常提交。结果:

Finished one cherry-pick.
# On branch old_cc
# Your branch is ahead of 'origin/old_cc' by 3 commits.


2. 如果在cherry-pick 的过程中出现了冲突

Automatic cherry-pick failed.  After resolving the conflicts,
mark the corrected paths with 'git add <paths>' or 'git rm <paths>'
and commit the result with:

        git commit -c 15a2b6c61927e5aed6718de89ad9dafba939a90b


就跟普通的冲突一样,手工解决:
2.1 $ git status    # 看哪些文件出现冲突

both modified:      app/models/user.rb

2.2 $ vim app/models/user.rb  # 手动解决它。
2.3 $ git add app/models/user.rb

2.4 git commit -c <新的commit号码>












### Git Cherry-Pick 的基本概念 `git cherry-pick` 是一种用于将单个或多个特定提交应用到当前分支的操作工具。它允许开发者从其他分支挑选某些提交并将其应用于另一个分支,而无需合并整个分支。 通过 `git cherry-pick` 命令可以实现以下功能: - 将某个分支中的单独提交引入到另一分支中。 - 解决跨分支开发时的代码同步需求。 此操作的核心在于指定要复制的具体提交哈希值(commit hash),从而仅提取该提交的内容及其更改[^5]。 --- ### 使用方法 #### 单次提交的应用 假设有一个提交记录为 `abc1234`,可以通过如下方式将其应用至当前分支: ```bash git cherry-pick abc1234 ``` 执行上述命令后,Git 会尝试重现目标提交所涉及的所有修改,并创建一个新的提交对象于当前分支上[^5]。 #### 多次连续提交的选择性应用 如果希望选取一系列连续的提交,比如从 `abc1234` 到 `def5678`,则可采用范围形式调用: ```bash git cherry-pick abc1234..def5678 ``` 注意这里的两个点号表示包含起始不包含结束;如果是三个点号,则意味着两端均被纳入考虑范围内[^5]。 对于非线性的历史结构或者复杂的场景下可能引发冲突的情况,请参阅下一节关于常见问题的部分处理办法。 --- ### 常见问题及解决方案 当运行 `cherry-pick` 过程遇到文件级别的差异无法自动解析时,会出现所谓的“merge conflict”。此时需手动编辑受影响区域直至消除矛盾之处后再继续流程: ```bash # 编辑完成后标记已解决状态 git add . # 继续完成剩余部分 git cherry-pick --continue ``` 另外,在中途决定放弃正在进行的任务时也可以随时中断过程并通过清理工作区来恢复原状: ```bash git cherry-pick --abort ``` 还有就是要注意的是,频繁使用 `cherry-pick` 可能会造成重复的历史条目累积,影响仓库整洁度以及后续维护成本增加等问题[^6]。 --- ### 示例代码展示 下面给出一个完整的例子演示如何利用 `git cherry-pick` 把远程服务器上的修复补丁快速拉取下来并集成进本地特性版本之中去。 假定存在这样的情况:远端 master 上已经包含了重要的错误修正但是尚未发布正式版;与此同时我们正在 feature-x 分支上面紧张忙碌着新特性的研发活动。为了尽早享受到这些改进成果而不必等待整体更新周期完毕,我们可以这样做: ```bash # 首先切换回主干以便定位确切位置 git checkout main git pull origin main # 查看日志找到那个关键修补程序对应的 commit id ,比如说 'a1b2c3d' git log --oneline # 跳转回到自己的专题线路 git checkout feature-x # 执行摘果子动作把那笔调整拿过来 git cherry-pick a1b2c3d ``` 这样就成功地让我们的私人项目享受到了公共主线里的最新优化进展啦! ---
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值