git reset --hard、git reset --sort及git revert区别
一、 在git操作中,有時候,進行了錯誤的提交,但是還沒有push到遠程分支,想要撤銷本次提交,可以使用git reset –-soft/hard命令。
1、二者區(qū)別:
git reset –-soft:回退到某個版本,只回退了commit的信息,不會恢復到index file一級。如果還要提交,直接commit即可;
git reset -–hard:徹底回退到某個版本,本地的源碼也會變?yōu)樯弦粋€版本的內(nèi)容,撤銷的commit中所包含的更改被沖掉;
2、具體用法如下:
使用git log命令查看本地的所有提交
最近一共進行了三次操作,分別是先創(chuàng)建了一個文件,wrote a file,然后修改加上我的名字后,再提交,操作說明add my name,第三次修改,加上我的年齡,提交說明add my age
使用命令git reset --hard head^(上一個版本就是HEAD^,上上一個版本就是HEAD^^,當然往上100個版本寫100個^比較容易數(shù)不過來,所以寫成HEAD~100)
將我加上我的年齡的那一次修改撤銷,執(zhí)行git log指令,可以看到,add my age 的commit 已經(jīng)被撤銷,打開文件查看:
修改的內(nèi)容也被撤銷了。
使用命令git reset --soft head^后,在用git log查看,發(fā)現(xiàn)add my age的commit的操作也被撤銷了,但是打開文件查看,
修改的內(nèi)容還在,即--soft
保留源碼,只回退到commit 信息到某個版本.不涉及index的回退,如果還需要提交,直接commit即可。
?
Revert撤銷一個提交的同時會創(chuàng)建一個新的提交。這是一個安全的方法,因為它不會重寫提交歷史。比如,下面的命令會找出倒數(shù)第二個提交,然后創(chuàng)建一個新的提交來撤銷這些更改,然后把這個提交加入項目中。
git revert HEAD~2相比git reset,它不會改變現(xiàn)在的提交歷史。因此,git revert可以用在公共分支上,git reset應該用在私有分支上。
你也可以把git revert當作撤銷已經(jīng)提交的更改,而git reset HEAD用來撤銷沒有提交的更改。
?
from:?https://zhuanlan.zhihu.com/p/32711219
總結
以上是生活随笔為你收集整理的git reset --hard、git reset --sort及git revert区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 代码回滚:Reset、Checkout、
- 下一篇: 16个不错的 git 别名