前言
日常的開發(fā),我們難免會(huì)創(chuàng)建錯(cuò)誤的git提交記錄,整個(gè)時(shí)候git給我們提供了兩個(gè)命令來(lái)解決這個(gè)問(wèn)題。一個(gè)命令是git reset,另一個(gè)是git revert。兩者有啥區(qū)別呢??jī)烧咧饕膮^(qū)別是,git reset命令是回滾某次提交,被回滾的提交將不會(huì)出現(xiàn)在提交記錄中,而git revert命令是創(chuàng)建一個(gè)新的提交來(lái)達(dá)到撤銷的目的,被撤銷的提交和撤銷的提交都會(huì)出現(xiàn)在提交記錄中。
準(zhǔn)備
首先呢,我們還是需要準(zhǔn)備一個(gè)git倉(cāng)庫(kù),并且準(zhǔn)備一個(gè)可以修改的文件,文件名無(wú)所謂,我這里就創(chuàng)建了一個(gè)README.md文件:
mkdir git-test
cd git-test
git init
touch README.md
git add *
git commit -m "init"
git reset
1.修改README文件。
2.提交這次修改。
3.假設(shè)剛剛的提交是個(gè)錯(cuò)誤的,我們需要回退,這個(gè)是個(gè)git reset命令就有用武之地了,我們可以使用它回退到指定的提交。
$ git reset e431092f22a85deebf7bd6f4f96d9943530b49bf
Unstaged changes after reset:
M README.md
4.我們?cè)谑褂胓it status查看狀態(tài),會(huì)發(fā)現(xiàn)README文件處于一個(gè)被修改的狀態(tài),并且內(nèi)容沒(méi)有發(fā)生變化。也就是說(shuō)git reset會(huì)將本地倉(cāng)庫(kù)的指針知到你指定的分支,但是內(nèi)容不會(huì)丟棄,而是放到了工作區(qū),如果你想再次提交還是可以的。
$ git status
On branch master
Changes not staged for commit:
(use "git add file>..." to update what will be committed)
(use "git checkout -- file>..." to discard changes in working directory)
modified: README.md
no changes added to commit (use "git add" and/or "git commit -a")
如果你想直接丟棄掉,可以加上--hard參數(shù)即可。其實(shí)git reset有三種回滾方式:
git reset --hard 回滾分支>
git reset --soft 回滾分支>
git reset --mixed 回滾方式>
- --hard回滾分支到當(dāng)前所在分支之間修改的內(nèi)容將會(huì)被完全丟棄掉。
- --soft會(huì)將修改的內(nèi)容放到暫存區(qū),你仍然可以使用git commit命令提交。
- --mixed則是reset的默認(rèn)參數(shù),也就是你不指定參數(shù)的話,會(huì)默認(rèn)使用--mixed回滾,這種回滾方式會(huì)將修改的內(nèi)容放到工作區(qū)。
git revert
有些情況下我們可能不太希望錯(cuò)誤的提交記錄被完全抹除掉,還是希望它保存在git的提交記錄中,萬(wàn)一我們撤銷出錯(cuò)了還可以有補(bǔ)救的機(jī)會(huì)。這中情況下我們就需要使用git revert命令來(lái)實(shí)現(xiàn)。
1.我們來(lái)查看下當(dāng)前git倉(cāng)庫(kù)的提交記錄。
$ git log
commit 28aef5f811895f7124a3ae0e3b095a37ef9cb299 (HEAD -> master)
Author: 代碼無(wú)止境 gancy.programmer@gmail.com>
Date: Sun Jun 23 18:08:30 2019 +0800
錯(cuò)誤的提交
commit e431092f22a85deebf7bd6f4f96d9943530b49bf
Author: 代碼無(wú)止境 gancy.programmer@gmail.com>
Date: Sun Jun 23 17:23:44 2019 +0800
init
2.現(xiàn)在我們需要將這個(gè)錯(cuò)誤的提交撤銷掉,執(zhí)行下面的命令就可以了。
git revert 28aef5f811895f7124a3ae0e3b095a37ef9cb299
在執(zhí)行的過(guò)程中會(huì)跳出來(lái)一個(gè)VI編輯界面,讓我們編輯撤銷提交的message信息,默認(rèn)為Revert "被撤銷提交的message",當(dāng)然我們可以進(jìn)行編輯。
3.在使用git log命令查看提交日志,我們會(huì)發(fā)現(xiàn)被撤銷的提交和撤銷的提交都出現(xiàn)在提交記錄中,然后你去查看README文件的內(nèi)容,會(huì)發(fā)現(xiàn)已經(jīng)回滾回去了。
$ git log
commit ef836162c8f4cf75086151e517339789dd937453 (HEAD -> master)
Author: 代碼無(wú)止境 gancy.programmer@gmail.com>
Date: Sun Jun 23 18:13:27 2019 +0800
Revert "錯(cuò)誤的提交"
This reverts commit 28aef5f811895f7124a3ae0e3b095a37ef9cb299.
commit 28aef5f811895f7124a3ae0e3b095a37ef9cb299
Author: 代碼無(wú)止境 gancy.programmer@gmail.com>
Date: Sun Jun 23 18:08:30 2019 +0800
錯(cuò)誤的提交
commit e431092f22a85deebf7bd6f4f96d9943530b49bf
Author: 代碼無(wú)止境 gancy.programmer@gmail.com>
Date: Sun Jun 23 17:23:44 2019 +0800
init
結(jié)束語(yǔ)
這篇文章,主要是講了回滾錯(cuò)誤提交的兩種方式,平時(shí)的使用場(chǎng)景還是挺多的,希望對(duì)大家能夠有所幫助。
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
您可能感興趣的文章:- 簡(jiǎn)單談?wù)凣it中的回滾操作
- git 刪除分支和回滾的實(shí)例詳解
- Git 撤銷操作、刪除文件和恢復(fù)文件
- Git里多種撤銷操作的最佳方法
- 基于Git的常用撤銷技巧與解決沖突方法(推薦)