大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

Git教程
Git標(biāo)簽管理
Git分支
Git操作
Git應(yīng)用
GitHub應(yīng)用
IDEA對于Git&GitHub的支持
Git與GitHub使用注意事項

Git撤銷修改

自然,你是不會犯錯的。不過現(xiàn)在是凌晨兩點,你正在趕一份工作報告,你在readme.txt中添加了一行:

$ cat readme.txt
Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.
My stupid boss still prefers SVN.

在你準(zhǔn)備提交前,一杯咖啡起了作用,你猛然發(fā)現(xiàn)了stupid boss可能會讓你丟掉這個月的獎金!

既然錯誤發(fā)現(xiàn)得很及時,就可以很容易地糾正它。你可以刪掉最后一行,手動把文件恢復(fù)到上一個版本的狀態(tài)。如果用git status查看一下:

$ 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.txt

no changes added to commit (use "git add" and/or "git commit -a")

你可以發(fā)現(xiàn),Git會告訴你,git checkout -- file可以丟棄工作區(qū)的修改:

$ git checkout -- readme.txt

命令git checkout -- readme.txt意思就是,把readme.txt文件在工作區(qū)的修改全部撤銷,這里有兩種情況:

一種是readme.txt自修改后還沒有被放到暫存區(qū),現(xiàn)在,撤銷修改就回到和版本庫一模一樣的狀態(tài);

一種是readme.txt已經(jīng)添加到暫存區(qū)后,又作了修改,現(xiàn)在,撤銷修改就回到添加到暫存區(qū)后的狀態(tài)。

總之,就是讓這個文件回到最近一次git commit或git add時的狀態(tài)。

現(xiàn)在,看看readme.txt的文件內(nèi)容:

$ cat readme.txt
Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.

文件內(nèi)容果然復(fù)原了。

git checkout -- file命令中的--很重要,沒有--,就變成了“切換到另一個分支”的命令,我們在后面的分支管理中會再次遇到git checkout命令。

現(xiàn)在假定是凌晨3點,你不但寫了一些胡話,還git add到暫存區(qū)了:

$ cat readme.txt
Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.
My stupid boss still prefers SVN.

$ git add readme.txt

慶幸的是,在commit之前,你發(fā)現(xiàn)了這個問題。用git status查看一下,修改只是添加到了暫存區(qū),還沒有提交:

$ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

	modified:   readme.txt

Git同樣告訴我們,用命令git reset HEAD 可以把暫存區(qū)的修改撤銷掉(unstage),重新放回工作區(qū):

$ git reset HEAD readme.txt
Unstaged changes after reset:
M	readme.txt

git reset命令既可以回退版本,也可以把暫存區(qū)的修改回退到工作區(qū)。當(dāng)我們用HEAD時,表示最新的版本。

再用git status查看一下,現(xiàn)在暫存區(qū)是干凈的,工作區(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.txt

還記得如何丟棄工作區(qū)的修改嗎?

$ git checkout -- readme.txt

$ git status
On branch master
nothing to commit, working tree clean

整個世界終于清靜了!

現(xiàn)在,假設(shè)你不但改錯了東西,還從暫存區(qū)提交到了版本庫,怎么辦呢?還記得版本回退一節(jié)嗎?可以回退到上一個版本。不過,這是有條件的,就是你還沒有把自己的本地版本庫推送到遠(yuǎn)程。還記得Git是分布式版本控制系統(tǒng)嗎?我們后面會講到遠(yuǎn)程版本庫,一旦你把stupid boss提交推送到遠(yuǎn)程版本庫,你就真的慘了……

小結(jié)

又到了小結(jié)時間。

場景1:當(dāng)你改亂了工作區(qū)某個文件的內(nèi)容,想直接丟棄工作區(qū)的修改時,用命令git checkout -- file。

場景2:當(dāng)你不但改亂了工作區(qū)某個文件的內(nèi)容,還添加到了暫存區(qū)時,想丟棄修改,分兩步,第一步用命令git reset HEAD<file> ,就回到了場景1,第二步按場景1操作。

場景3:已經(jīng)提交了不合適的修改到版本庫時,想要撤銷本次提交,參考版本回退一節(jié),不過前提是沒有推送到遠(yuǎn)程庫。

全部教程
主站蜘蛛池模板: 久久国语| jizz中国女人| 欧美日韩三级 | 精品欧美一区二区精品久久 | 真实国产精品视频国产网 | 成人激情开心网 | 日本一级毛片2021免费 | 中文字幕亚洲综合久久202 | 拍真实国产伦偷精品 | 久久国产影院 | 噜噜嘿在线视频免费观看 | 午夜大片免费男女爽爽影院久久 | 欧美 日产 国产精选 | 亚洲精品一区二区卡 | 天天草天天草 | 日韩欧美亚洲一区精选 | 日韩二区三区 | 欧美日韩精品一区二区三区四区 | 夜间福利影院 | 欧美一区二区视频 | 精品国产一区二区三区2021 | 精品动漫中文字幕一区二区三区 | 色婷婷5月精品久久久久 | 日本中文在线观看 | 欧美一区二区三区婷婷月色 | 男人天堂黄色 | 国产精品一区二区久久精品涩爱 | 日韩欧美第一页 | 免费费看的欧亚很色大片 | 国产成人综合95精品视频免费 | 四虎成人免费观看在线网址 | 奇米影视77 | 国产成人午夜精品5599 | 免费视频一级片 | 久久精彩免费视频 | 久久久久久99精品 | 国产精品99久久99久久久看片 | 真实偷拍激情啪啪对白 | 奇米影视狠狠久久中文 | 成人精品一区二区三区校园激情 | 四虎aⅴ |