Git patch的使用方法和场景

        Git patch在同步不同分支的代码时应用较多,且比较灵活,方便我们对不同发行版本的版本管理和控制。比如修复了基线的一个bug,同步到各个版本的发布分支。本文介绍使用diff/apply生成和应用补丁。

        diff/apply的打patch方案:

        使用diff命令生成patch文件,后使用apply命令应用patch到分支,从而实现修改复刻。其大致流程如下:

# 生成补丁

git diff > commit.patch

# 检查补丁

git apply --check commit.patch

# 应用补丁

git apply commit.patch

git diff

        没有指定任何版本,那默认就是对lastCommit和working copy之间作比较。

        这里就会出现两种情况:如果当前的working copy已经commit过了,那么lastCommit就是目前working copy自身,所以diff不会输出任何内容;如果当前的working copy未commit,那么diff就会输出本次修改的内容。

git diff commitId

        指定了一个commitId,那就是对commitId和working copy之间作比较。同样的,如果你的working copy已经commit过了,那么这个命令会等价于git diff commitId lastCommitId。

git diff commitId1 commitId2

        指定了两个commitId(注意把时间早的commitId放在前面),这种情况就是对commitId1和commitId2之间作比较。

(1).本地修改未commit

希望把修改的内容生成patch,可以如下操作:

git diff > commit.patch

(2).对于已经add但是未commit的修改:

git diff --cached > commit.patch

(3).本地修改已commit

希望把最近一次的修改生成patch:

# 注意:commitId为倒数第二个提交ID

git diff commitId > commit.patch

apply应用patch

生成patch文件后,我们切换到希望应用patch的分支,然后按下面的步骤操作:

# 检查patch是否可以应用

git apply --check commit .patch

# 打单个补丁

git apply commit .patch

# 打多个补丁

git apply ../patch/*.patch

        打完补丁后再add/commit进行提交。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大王算法

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值