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