git diff 利用打patch的方式移植分支间的改动

本文介绍了如何利用git diff和patch在不同分支间移植改动。通过对比工作目录、暂存区与版本库的状态,以及执行git diff branch1 branch2来比较两个分支的差异。当需要将分支branch2的改动移植到branch1时,创建补丁并应用,可能遇到的冲突及解决方法,如添加--binary选项和忽略警告。
摘要由CSDN通过智能技术生成

开发过程中,我们需要了解当前每个改动。在版本控制系统中用来显示两个版本之间差别的操作,我们称之为“diff” 或者“patch”补丁

执行git add之后,提交的改动就是在暂存区
git diff 指工作目录下的改动,即工作目录树与暂存区之间的区别
git diff –cached 指暂存区与版本库最后一个版本的区别(用来查看执行git add后保存的改动)
git diff HEAD 指工作目录树(暂存区与非暂存区)与版本库最后一个版本的差别

比较两个分支: git diff branch1 branch2
如果我们想要把其中一个分支branch2的改动打包到分支branch1上,那就需要打补丁

git diff branch1 branch2 > diff.patch

然后将上面补丁应用到branch1上

git checkout branch1
git apply diff.patch

如果没有冲突,上面就可以将branch2上完整的改动移植到branch1了,但是操作过程中可以会有冲突,会提示下面错误

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值