git revert和git reset的區(qū)別詳解
git revert和git reset的區(qū)別
git revert 是生成一個新的提交來撤銷某次提交,此次提交之前的commit都會被保留
git reset 是回到某次提交,提交及之前的commit都會被保留,但是此次之后的修改都會被退回到暫存區(qū)
具體一個例子,假設(shè)有三個commit, git st:
commit3: add test3.c
commit2: add test2.c
commit1: add test1.c
當執(zhí)行g(shù)it revert HEAD~1時, commit2被撤銷了
git log可以看到:
revert "commit2":this reverts commit 5fe21s2...
commit3: add test3.c
commit2: add test2.c
commit1: add test1.c
git status 沒有任何變化
如果換做執(zhí)行g(shù)it reset --soft(默認) HEAD~1后,運行g(shù)it log
commit2: add test2.c
commit1: add test1.c
運行g(shù)it status, 則test3.c處于暫存區(qū),準備提交。
如果換做執(zhí)行g(shù)it reset --hard HEAD~1后,
顯示:HEAD is now at commit2,運行g(shù)it log
commit2: add test2.c
commit1: add test1.c
運行g(shù)it st, 沒有任何變化
另外:
git revert <commit log string>是撤消該commit,作為一個新的commit。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Cygwin下安裝vim后,vim中退格鍵無法正常使用的解決方法
下面小編就為大家?guī)硪黄狢ygwin下安裝vim后,vim中退格鍵無法正常使用的解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02linux shell中 if else以及大于、小于、等于邏輯表達式介紹
在linux shell編程中,大多數(shù)情況下,可以使用測試命令來對條件進行測試,這里簡單的介紹下,方便需要的朋友2013-02-02fedora 23 lvm2格式 根目錄磁盤空間不足 擴容方法
下面小編就為大家?guī)硪黄猣edora 23 lvm2格式 根目錄磁盤空間不足 擴容方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02Shell腳本中使用for循環(huán)和cat命令實現(xiàn)按順序合并文件
這篇文章主要介紹了Shell腳本中使用for循環(huán)和cat命令實現(xiàn)按順序合并文件,本文先是用sed命令來實現(xiàn),發(fā)現(xiàn)不能完成需求,后使用for循環(huán)解決,需要的朋友可以參考下2015-01-01