当前位置:首页 > 开发工具 > Git使用小技巧之挑拣合并

Git使用小技巧之挑拣合并

2022年09月16日 22:26:05开发工具6

先想想一个情况,现在我们有一个功能急需要发布到线上,但是这个功能相关的代码所在的测试分(test)支有很多不应该发布的代码,那么这个时候我们就需要将与这个代码相关的提交选择性的合并到master上并发布。如果你还不知道git cherry-pick命令的话,很有可能你会从master分支上检出一个新分支,然后在把相关的代码copy到新分支上然后再合并回master。当然这么做确实可以达到最终的目的,但是手动copy很容易遗漏某些东西,那么我们这篇文章就来讲解一下git cherry-pick命令。

准备

1.准备一个空的git仓库,并创建一个readme文件然后提交。

mkdir git-test
cd git-test
git init
touch README.md
git add README.md
git commit -m "第一次提交"

2.基于master创建一个新的分支dev

git checkout -b dev

3.修改两次README.md文件,并commit两次。执行git log后我们会看到如下内容:

$ git log
commit cc04beabf0678f54bf64635bd56160c78b0aa1e6 (HEAD -> dev)
Author: 代码无止境 <gancy.programmer@gmail.com>
Date:   Mon Jun 17 18:35:44 2019 +0800

    第三次提交

commit 32259aa35d0702d2d05c648938798f9a5bd4b9e7
Author: 代码无止境 <gancy.programmer@gmail.com>
Date:   Mon Jun 17 18:35:23 2019 +0800

    第二次提交

commit e7f478807d478a0c3e0af8659e0733a9d5b32c8b (master)
Author: 代码无止境 <gancy.programmer@gmail.com>
Date:   Mon Jun 17 18:34:09 2019 +0800

    第一次提交

git cherry-pick

经过上面的步骤一个git cherry-pick的使用场景就已经被我们模拟出来了。假如说我们现在dev上的第二次提交就是我们现在急需要发布的功能,那么我们就需要使用git cherry-pick命令将这次提交合并到master分支上。
1.在dev分支上执行git log命令,找到目标commit的commitid.
2.切换到master分支

git checkout master

3.执行git cherry-pick命令

git cherry-pick 32259aa35d0702d2d05c648938798f9a5bd4b9e7

4.再次执行git log命令就可以看到目标提交已经被合并到master上了

$ git log
commit 845d18e1193e4ad4361c8065173ed9b96fcc5227 (HEAD -> master)
Author: 代码无止境 <gancy.programmer@gmail.com>
Date:   Mon Jun 17 18:35:23 2019 +0800

    第二次提交

commit e7f478807d478a0c3e0af8659e0733a9d5b32c8b
Author: 代码无止境 <gancy.programmer@gmail.com>
Date:   Mon Jun 17 18:34:09 2019 +0800

    第一次提交

git cherry-pick 相关参数

上面只是git cherry-pick命令的简单用法,其实这个命令还提供了不少的参数。

git cherry-pick [<options>] <commit-ish>...

常用options:
    --quit                退出当前的chery-pick序列
    --continue            继续当前的chery-pick序列
    --abort               取消当前的chery-pick序列,恢复当前分支
    -n, --no-commit       不自动提交
    -e, --edit            编辑提交信息

如果我们执行git cherry-pick合并之后发生了冲突,这个时候Git会自动帮我们新建一个分支,如下所示:

MINGW64 ~/Desktop/p/write/笔记/git-test (master|CHERRY-PICKING)

如果我们想取消这次合并可以执行git cherry-pick --quit或者git cherry-pick --abort命令取消这次挑拣。
二者不同的地方在于前者会将当前分支中未冲突的内容状态变为modified,
而后者则会直接将当前分支的内容回退到挑拣之前的状态。当然如果我们也可以解决冲突之后执行如下命令继续合并:

git add *
git cherry-pick --continue

后面的-n和-e,就比较容易理解了,-n就是挑拣后不会自动提交,需要我们执行git commit命令进行提交,而-e则是可以改变挑拣的message信息。

作者:代码无止境
来源链接:https://www.cnblogs.com/endless-code/p/11093861.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。


本文链接:https://www.javaclub.cn/tool/42292.html

标签: Git合并
分享给朋友:

“Git使用小技巧之挑拣合并” 的相关文章

Git 管理工具 SourceTree 的使用(上手简单,不熟悉git命令的开发者必用)

Git 管理工具 SourceTree 的使用(上手简单,不熟悉git命令的开发者必用)

目录 一、SourceTree 概述 二、SourceTree 使用方法 1. 克隆 Git 仓库至本地 2. 推送本地的文件至远程仓库 3. 创建/切换/合并分支 4. 版本回退 一、SourceTree 概述 &...

关于Git的一些经验总结

目录 1.初始化仓库 2.添加文件到仓库 3.关于版本回退 4.关于修改 5.删除...

Git之常见的分支操作

Git之常见的分支操作

目录 分支管理 1.创建与合并分支...

Mac下修改git用户名,邮箱

https://blog.csdn.net/helinlin007/article/details/52266169 首先进入vi ~/.gitconfig进入对应txt 文件,在里面 修改即可 作者:小贞贞 来源链接:https://blog.csdn.net...

Git的安装教程(完成clone一个项目到本地)

Git的安装教程(完成clone一个项目到本地)

官网下载安装包地址:点击进入 https://git-scm.com/download/win 但是官网下载比较慢,我们这里选择国内阿里镜像点击进入 https://npm.taobao.org/mirro...

如何将idea项目上传到Git

如何将idea项目上传到Git

Git是一款免费的分布式版本控制工具。每个人的电脑都是一个完整的版本库,那么我们该如何将一个java项目上传到Git呢? 一、准备工作 1、Git下载及安装 https://jingyan.baidu.com/article/7f766dafba84f04101...

Git批量删除本地分支

删除分支命令 删除一条分支: git branch -D branchName 删除当前分支外的所有分支: git branch | xargs git branch -d 删除分...

Git 的基本语法

Git 的基本语法

git 创建版本库         版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时...

Git回滚到上一次提交的节点

Git回滚到上一次提交的节点

有这样的情况,在代码提交完成之后, 发现出了问题,需要回滚到上一次提交的节点,怎么做呢。 首先找到git提交的日志 git log 找到最近一次提交,复制提交的信息码,如图: 复制该信息码,然后控制台revert一下,就OK...

SourceTree Gitflow 使用一 (Git项目转Gitflow)

SourceTree Gitflow 使用一 (Git项目转Gitflow)

1.克隆项目到本地 2.SourceTree 打开克隆的项目 3 点击master 点击右上角git工作流 作者:1024+ 来源链接:https://blog.csdn.net/li3715...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。