某个commit,比如 c1,,最早是在a分支做的,当被cherry-pick到b分之后,还是一样的revision吗?
做实验:
test_cherry_pick1
和 test_cherry_pick2
分支,起点一样。test_cherry_pick1
分支,新增改动,提交得到 c1(42f31d5c96be19a4b5f00e7e986799147ba66139)test_cherry_pick2
,cherry-pick c1 到该分支结论
大为震惊,居然不一样,得到的是 0a5f55380aec54880a0759102c4841dd467b39d0, 跟之前的居然不一样!!
关于 github 的三点对比
做实验:
三点比较:因为所有在 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里所没有的,文件之间是有差异的