成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

關(guān)于Git的撤銷命令:如何在Git中撤銷一切

移動開發(fā) 前端
當你完成了一次新的提交(commit),Git會及時存儲當前時刻倉庫(repository)的快照(snapshot);你能夠使用Git將項目回退到任何之前的版本。

任何一個版本控制系統(tǒng)中,最有用的特性之一莫過于 “撤銷(undo)”操作。在Git中,“撤銷”有很多種含義。

當你完成了一次新的提交(commit),Git會及時存儲當前時刻倉庫(repository)的快照(snapshot);你能夠使用Git將項目回退到任何之前的版本。

下文中,我將列舉幾個常見的、需要“撤銷”的場景,并且展示如何使用Git來完成這些操作。

一、撤銷一個公共修改 Undo a "public" change

場景:你剛剛用git push將本地修改推送到了GitHub,這時你意識到在提交中有一個錯誤。你想撤銷這次提交。

使用撤銷命令:git revert

發(fā)生了什么:git revert將根據(jù)給定SHA的相反值,創(chuàng)建一個新的提交。如果舊提交是“matter”,那么新的提交就是“anti-matter”——舊提交中所有已移除的東西將會被添加進到新提交中,舊提交中增加的東西將在新提交中移除。

這是Git最安全、也是最簡單的“撤銷”場景,因為這樣不會修改歷史記錄——你現(xiàn)在可以git push下剛剛revert之后的提交來糾正錯誤了。

二、修改最近一次的提交信息 Fix the last commit message

場景:你只是在最后的提交信息中敲錯了字,比如你敲了git commit -m "Fxies bug #42",而在執(zhí)行g(shù)it push之前你已經(jīng)意識到你應(yīng)該敲"Fixes bug #42"。

使用撤銷命令:git commit –amend或git commit --amend -m "Fixes bug #42"

發(fā)生了什么:git commit –amend將使用一個包含了剛剛錯誤提交所有變更的新提交,來更新并替換這個錯誤提交。由于沒有staged的提交,所以實際上這個提交只是重寫了先前的提交信息。

三、撤銷本地更改 Undo "local" changes

場景:當你的貓爬過鍵盤時,你正在編輯的文件恰好被保存了,你的編輯器也恰在此時崩潰了。此時你并沒有提交過代碼。你期望撤銷這個文件中的所有修改——將這個文件回退到上次提交的狀態(tài)。

使用撤銷命令:git checkout --

發(fā)生了什么:git checkout將工作目錄(working directory)里的文件修改成先前Git已知的狀態(tài)。你可以提供一個期待回退分支的名字或者一個確切的SHA碼,Git也會默認檢出HEAD——即:當前分支的上一次提交。

注意:用這種方法“撤銷”的修改都將真正的消失。它們永遠不會被提交。因此Git不能恢復(fù)它們。此時,一定要明確自己在做什么!(或許可以用git diff來確定)

四、重置本地修改 Reset "local" changes

場景:你已經(jīng)在本地做了一些提交(還沒push),但所有的東西都糟糕透了,你想撤銷最近的三次提交——就像它們從沒發(fā)生過一樣。

使用撤銷命令:git reset或git reset --hard

發(fā)生了什么:git reset將你的倉庫紀錄一直回退到指定的最后一個SHA代表的提交,那些提交就像從未發(fā)生過一樣。默認情況下,git reset會保留工作目錄(working directory)。這些提交雖然消失了,但是內(nèi)容還在磁盤上。這是最安全的做法,但通常情況是:你想使用一個命令來“撤銷”所有提交和本地修改——那么請使用--hard參數(shù)吧。

五、撤銷本地后重做 Redo after undo "local"

場景:你已經(jīng)提交了一些內(nèi)容,并使用git reset –hard撤銷了這些更改(見上面),突然意識到:你想還原這些修改!

使用撤銷命令:git reflog和git reset, 或者git checkout

發(fā)生了什么:git reflog是一個用來恢復(fù)項目歷史記錄的好辦法。你可以通過git reflog恢復(fù)幾乎任何已提交的內(nèi)容。

你或許對git log命令比較熟悉,它能顯示提交列表。git reflog與之類似,只不過git reflog顯示的是HEAD變更次數(shù)的列表。

一些說明:

1. 只有HEAD會改變。當你切換分支時,用git commit提交變更時,或是用git reset撤銷提交時,HEAD都會改變。但當你用git checkout --時, HEAD不會發(fā)生改變。(就像上文提到的情形,那些更改根本就沒有提交,因此reflog就不能幫助我們進行恢復(fù)了)

2. git reflog不會永遠存在。Git將會定期清理那些“不可達(unreachable)”的對象。不要期望能夠在reflog里找到數(shù)月前的提交記錄。

3. reflog只是你個人的。你不能用你的reflog來恢復(fù)其他開發(fā)者未push的提交。

 

因此,怎樣合理使用reflog來找回之前“未完成”的提交呢?這要看你究竟要做什么:

1. 如果你想恢復(fù)項目歷史到某次提交,那請使用git reset --hard

2. 如果你想在工作目錄(working direcotry)中恢復(fù)某次提交中的一個或多個文件,并且不改變提交歷史,那請使用git checkout--

3. 如果你想確切的回滾到某次提交,那么請使用git cherry-pick。

六、與分支有關(guān)的那些事 Once more, with branching

場景:你提交了一些變更,然后你意識到你正在master分支上,但你期望的是在feature分支上執(zhí)行這些提交。

使用撤銷命令:git branch feature, git reset --hard origin/master, 和 git checkout feature

發(fā)生了什么:你可能用的是git checkout -b來建立新的分支,這是創(chuàng)建和檢出分支的便捷方法——但實際你并不想立刻切換分支。git branch feature會建立一個叫feature的分支,這個分支指向你最近的提交,但是你還停留在master分支上。

git reset --hard將master回退至origin/master,并忽略所有新提交。別擔心,那些提交都還保留在feature上。

最后,git checkout將分支切換到feature,這個分支原封不動的保留了你最近的所有工作。

七、事半功倍處理分支 Branch in time saves nine

場景:你基于master新建了一個feature分支,但是master分支遠遠落后與origin/master。現(xiàn)在master分支與origin/master同步了,你期望此刻能在feature下立刻commit代碼,并且不是在遠遠落后master的情況下。

使用撤銷命令:git checkout feature和git rebase master

發(fā)生了什么:你也許已經(jīng)敲了命令:git reset(但是沒用--hard,有意在磁盤上保存這些提交內(nèi)容),然后敲了git checkout -b,之后重新提交更改,但是那樣的話,你將失去本地的提交記錄。不過,一個更好的方法:

使用git rebase master可以做到一些事情:

1.首先,它定位你當前檢出分支和master之間的共同祖先節(jié)點(common ancestor)。

2.然后,它將當前檢出的分支重置到祖先節(jié)點(ancestor),并將后來所有的提交都暫存起來。

3.最后,它將當前檢出分支推進至master末尾,同時在master最后一次提交之后,再次提交那些在暫存區(qū)的變更。

八、批量撤銷/找回 Mass undo/redo

場景:你開始朝一個既定目標開發(fā)功能,但是中途你感覺用另一個方法更好。你已經(jīng)有十幾個提交,但是你只想要其中的某幾個,其他的都可以刪除不要。

使用撤銷命令:git rebase -i

發(fā)生了什么:-i將rebases設(shè)置為“交互模式(interactive mode)”。rebase開始執(zhí)行的操作就像上文討論的一樣,但是在重新執(zhí)行某個提交時,它會暫停下來,讓你修改每一次提交。

rebase –i將會打開你的默認文本編輯器,然后列出正在執(zhí)行的提交,就像這樣:

 

前兩列最關(guān)鍵:第一列是選擇命令,它會根據(jù)第二列中的SHA碼選擇相應(yīng)的提交。默認情況下,rebase –i會認為每個更改都正通過pick命令被提交。

要撤銷一個提交,直接在編輯器刪除對應(yīng)的行就可以了。如果在你的項目不再需要這些錯誤的提交,你可以直接刪除上圖中的第1行和3-4行。

如果你想保留提交但修改提交信息,你可以使用reword命令。即,將命令關(guān)鍵字pick換成reword(或者r)。你現(xiàn)在可能想立刻修改提交消息,但這么做不會生效——rebase –i將忽略SHA列后的所有東西。現(xiàn)有的提交信息會幫助我們記住0835fe2代表什么。當你敲完rebase –i命令后,Git才開始提示你重寫那些新提交消息。

如果你需要將2個提交合并,你可以用squash或者fixup命令,如下圖:

 

squash和fixup都是“向上”結(jié)合的——那些用了這些合并命令(編者按:指squash、fixup)的提交,將會和它之前的提交合并:上圖中,0835fe2和6943e85將會合并成一個提交,而38f5e4e和af67f82將會合并成另一個提交。

當你用squash時,Git將會提示是否填寫新的提交消息;fixup則會給出列表中第一個提交的提交信息。在上圖中,af67f82是一個“Ooops”信息,因為這個提交信息已經(jīng)同38f5e4e一樣了。但是你可以為0835fe2和6943e85合并的新提交編寫提交信息。

當你保存并退出編輯器時,Git將會按照從上到下的順序執(zhí)行你的提交。你可以在保存這些提交之前,修改提交的執(zhí)行順序。如果有需要,你可以將af67f82和0835fe2合并,并且可以這樣排序:

 

九、修復(fù)早先的提交 Fix an earlier commit

場景:之前的提交里落下了一個文件,如果先前的提交能有你留下的東西就好了。你還沒有push,并且這個提交也不是最近的提交,因此你不能用commit –amend。

使用撤銷命令:git commit --squash和git rebase --autosquash -i

發(fā)生了什么:git commit –squash將會創(chuàng)建一個新的提交,該提交信息可能像這樣“squash! Earlier commit”。(你也可以手寫這些提交信息,commit –squash只是省得讓你打字了)。

如果你不想為合并的提交編寫信息,也可以考慮使用命令git commit --fixup。這種情況下,你可能會使用commit --fixup,因為你僅希望在rebase中使用之前的提交信息。

rebase --autosquash –i將會啟動rebase交互編輯器,編輯器會列出任何已完成的squash!和fixup!提交,如下圖:

 

當使用--squash和–fixup時,你或許記不清你想修復(fù)的某個提交的SHA碼——只知道它可能在一個或五個提交之前。你或許可以使用Git的^和~操作符手動找回。HEAD^表示HEAD的前一次提交。HEAD~4表示HEAD前的4次提交,加起來總共是前5次提交。

十、停止跟蹤一個已被跟蹤的文件 Stop tracking a tracked file

場景:你意外將application.log添加到倉庫中,現(xiàn)在你每次運行程序,Git都提示application.log中有unstaged的提交。你在.gitignore中寫上”*.log”,但仍舊沒用——怎樣告訴Git“撤銷”跟蹤這個文件的變化呢?

使用撤銷命令: git rm --cached application.log

發(fā)生了什么:盡管.gitignore阻止Git跟蹤文件的變化,甚至是之前沒被跟蹤的文件是否存在,但是,一旦文件被add或者commit,Git會開始持續(xù)跟蹤這個文件的變化。類似的,如果你用git add –f來“強制”add,或者覆蓋.gitignore,Git還是會繼續(xù)監(jiān)視變化。所以以后最好不要使用–f來add .gitignore文件。

如果你希望移除那些應(yīng)當被忽略的文件,git rm –cached可以幫助你,并將這些文件保留在磁盤上。因為這個文件現(xiàn)在被忽略了,你將不會在git status中看到它,也不會再把這個文件commit了。

以上就是如何在Git上撤銷的方法。如果你想學(xué)習(xí)更多Git命令用法,可以移步下面相關(guān)的文檔:

checkout

commit

rebase

reflog

reset

revert

rm

責任編輯:chenqingxiang 來源: CocoaChina
相關(guān)推薦

2022-10-27 09:34:06

git撤銷

2017-11-13 12:44:30

Git命令工具

2020-10-14 08:04:28

JavaScrip

2020-09-11 10:55:10

useState組件前端

2021-02-28 09:47:54

軟件架構(gòu)軟件開發(fā)軟件設(shè)計

2018-11-23 11:17:24

負載均衡分布式系統(tǒng)架構(gòu)

2021-02-19 23:08:27

軟件測試軟件開發(fā)

2023-11-14 14:21:43

Git三路合并

2021-05-28 07:12:59

Python閉包函數(shù)

2022-08-21 17:35:31

原子多線程

2023-04-20 10:15:57

React組件Render

2022-08-17 06:25:19

偽共享多線程

2018-01-17 09:15:52

負載均衡算法

2023-04-12 14:04:48

光纖網(wǎng)絡(luò)

2022-04-02 09:38:00

CSS3flex布局方式

2023-02-10 08:44:05

KafkaLinkedIn模式

2018-01-05 14:23:36

計算機負載均衡存儲

2023-07-10 10:36:17

人工智能AI

2021-08-09 14:40:02

物聯(lián)網(wǎng)IOT智能家居

2024-08-26 11:59:35

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 欧美一区二区三区四区在线 | 久久精品国产久精国产 | 在线观看免费av网 | 欧美一级在线免费观看 | 亚洲成人中文字幕 | 99热在这里只有精品 | 夜夜爽99久久国产综合精品女不卡 | 成人亚洲性情网站www在线观看 | 亚洲视频免费观看 | 国产日产精品一区二区三区四区 | 欧美日韩久久精品 | 黄色欧美在线 | 欧美亚洲在线 | 免费观看的黄色网址 | 成人福利视频 | 久艹网站 | 99久久精品免费看国产四区 | 国产色婷婷精品综合在线播放 | 国产www成人 | 成人午夜精品 | 一区二区三区四区不卡 | 伊人久麻豆社区 | 久久国产欧美一区二区三区精品 | 国产一区二区在线播放 | 97精品超碰一区二区三区 | 日韩三级在线 | 精品欧美乱码久久久久久 | 亚洲精品99 | 成人av播放| 三级高清 | 国产一区二区三区在线 | 午夜影院在线观看 | 亚洲69p| 久久久www成人免费无遮挡大片 | 一区二区三区av | 久久国产精品视频 | 视频一区二区国产 | 精品一区二区久久久久久久网站 | 日韩欧美三区 | 中文字幕在线免费观看 | 婷婷福利视频导航 |