Git版本回退中的Git revert 和 Git reset 區(qū)別

Git revert 和 git reset 的區(qū)別

1.?git reset 是把HEAD指針向后移動(dòng)了一下,而git revert是HEAD指針繼續(xù)前進(jìn),只是新的commit的內(nèi)容和要revert的內(nèi)容正好相反,能夠抵消要被revert的內(nèi)容(如下圖):

例子:同樣是從C版本退回到B版本,git revert 和git reset --hard 的處理邏輯

Git revert commit_id?回退前(用git log --pretty=oneline查看的結(jié)果):HEAD 指針指向 版本C 也就是 版本3

Git revert commit_id 回退后 (用git log --pretty=oneline查看的結(jié)果):HEAD 指針指向 新版本(Revert "版本B") 也就是 版本4 ,之前的 版本3 被保留下來(lái)了


git reset --hard commit_id 回退前(用git log --pretty=oneline查看的結(jié)果):HEAD 指針指向? 版本3

git reset --hard commit_id 回退后(用git log --pretty=oneline查看的結(jié)果): HEAD 指針指向 版本2,之前的 版本3 被干掉了 (雖然這里被干掉了,我們還是可以通過(guò) git relog 的方式找到版本3的Commit_id,再通過(guò) git reset --hard commit_id 的方式進(jìn)行恢復(fù))

2.?git revert是用一次新的commit來(lái)回滾之前的commit,git reset是直接刪除指定的commit


3. 在回滾這一操作上看,效果差不多。但是在日后繼續(xù)合并(merge)以前的老版本時(shí)有區(qū)別。因?yàn)間it revert是用一次逆向的commit“中和”之前的提交,因此日后合并老的branch時(shí),導(dǎo)致這部分改變不會(huì)再次出現(xiàn),但是git reset是之間把某些commit在某個(gè)branch上刪除,因而和老的branch再次merge時(shí),這些被回滾的commit應(yīng)該還會(huì)被引入。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容