从history1分出来的A, B两个branch
A上有一些更改,例如
changeA2
changeA1
history1
B上有一些更改,例如
changeB2
changeB1
history1
---------------------
此时想把B branch上的改动merge到A branch,于是在A branch上执行 git merge B, 执行完毕后A branch的commit记录可能如下:
merge branch ‘B‘ into A
changeA2
changeB2
changeB1
changeA1
history1
此时突然发现情况不对,想把刚才A上刚才的merge取消,遂在A上执行 git revert -m 1 <merge commit的SHA1码>,此时commit记录变成如下状态:
revert “merge branch ‘B‘ into A”
merge branch ‘B‘ into A
changeA2
changeB2
changeB1
changeA1
history1
注意,这时候如果你想再把B branch上的change merge回A上已经不可能了,当执行revert “merge branch ‘B‘ into A”的时候你告诉git不要merge B上的东西(任何基于B的branch都不能merge了),解决方法有两种:
1. 把revert “merge branch ‘B‘ into A”这个commit再revert回去,这一般不太可行,好不容易revert过来的又revert回去么?遂方法2
2. B上的change有些有用,又不想都放弃掉,此时在B上执行git reset <history1的SHA1码>, 也就是把B的头指针指到刚分出来时候的那个commit点,这时候改动还在,只不过都变成unstage状态,这时速度把不对的地方改过来,重新commit一下,此时B的commit记录变为:
NewChangeB
history1
此时再在A上merge B上的更改就可以了