git的实验:cherry-pick,github对比代码的两种方式

某个commit,比如 c1,,最早是在a分支做的,当被cherry-pick到b分之后,还是一样的revision吗?

实验1:c1被cherry-pick到别的分支后,revision不变对吗?(答案是变了)

做实验:

  1. 从main分支拉出 test_cherry_pick1test_cherry_pick2 分支,起点一样。
  2. test_cherry_pick1 分支,新增改动,提交得到 c1(42f31d5c96be19a4b5f00e7e986799147ba66139)
  3. 切换到 test_cherry_pick2,cherry-pick c1 到该分支
  4. 检查一下两个分支关于该改动的uuid(commit id)是否一样?

结论

大为震惊,居然不一样,得到的是 0a5f55380aec54880a0759102c4841dd467b39d0, 跟之前的居然不一样!!


实验2:三点对比和两点对比

关于 github 的三点对比

  • 三点对比commit差异
  • 两点对比绝对差异

做实验:

  1. 从main分支拉出 test_two_way_diff1 和 test_two_way_diff2 分支,起点相同
  2. test_two_way_diff1 分支修改某个文件的a行,提交,产生 c1(aa400fb)
  3. test_two_way_diff2 分支修改该文件的的b行,提交,产生c2 (e872e65)
  4. 合并 test_two_way_diff2 到 test_two_way_diff1 (产生了c3 4a38f1e 来承载合并)
  5. 使用三点对比和两点对比,感受一下对比的结果的差异
  • 三点比较:因为所有在 test_two_way_diff2 的commit,在test_two_way_diff1 都包含,所以是没有差异的(这种就是对比了commit

    三点比较是因为用三个点 ... 隔开两个比较的分支,如:https://github.com/xxxxx/test_pr_private/compare/master…test_cherry_pick1

    两点比较是用了两个店 .. 如:https://github.com/xxxxx/test_pr_private/compare/master…test_cherry_pick1

    在这里插入图片描述

在这里插入图片描述

可以看到 test_two_wa_diff1 分支按照时间由近到远是由这些

commit组成的

4a38f1e

e872e65

aa400fb

所以可以发现,其实将 test_two_way_diff2 合并到 test_two_way_diff1之后,其 e872e65 也是被囊括在 test_two_way_diff1 里了这就是为什么用两点对比(对比commit)的时候 test_two_way_diff2相对于 test_two_way_diff1 没有任何更改,因为2里有的1都有了没有更多需要合并过来的commit了

  • 两点比较:比较的是 .. 后面的分支相较于前面的分支的绝对差异(文件的差异)

    可以看到文件差异肯定是有的,毕竟 test_cherry_pick1 里头有些改动是 test_cherry_pick1里所没有的,文件之间是有差异的

    在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值