码迷,mamicode.com
首页 > 其他好文 > 详细

Git --恢复修改的文件

时间:2019-02-07 13:43:41      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:add   tom   更新   row   版本号   一个   ssis   org   git log   

对于恢复修改的文件,就是将文件从仓库中拉到本地工作区,即 仓库区 ----> 暂存区 ----> 工作区。

对于修改的文件有两种情况:

  • 只是修改了文件,没有任何 git 操作
  • 修改了文件,并提交到暂存区(即编辑之后,gitaddgitadd但没有 git commit -m ....)
  • 修改了文件,并提交到仓库区(即编辑之后,gitaddgitadd和 git commit -m ....)

情况I:

只是修改了文件,没有任何 git 操作,直接一个命令就可回退:

$ git checkout -- aaa.txt # aaa.txt为文件名

情况II:

修改了文件,并提交到暂存区(即编辑之后,gitaddgitadd但没有 git commit -m ....)

$ git log --oneline    # 可以省略
$ git reset HEAD    # 回退到当前版本
$ git checkout -- aaa.txt    # aaa.txt为文件名

 情况III:

修改了文件,并提交到仓库区(即编辑之后,gitaddgitadd和 git commit -m ....)

 

$ git log --oneline    # 可以省略
$ git reset HEAD^    # 回退到上一个版本
$ git checkout -- aaa.txt    # aaa.txt为文件名

 

【注1】情况II 和 情况III 只有回退的版本不一样,

对于 情况II,并没有 $ git commit,仓库版本也就不会更新和记录,所以回退的是当前版本

技术图片

对于情况III,一旦 $ git commit,仓库版本就会更新并记录,所以要回退的也就是上一个版本

技术图片

【注2】$ git reset 版本号    ----  将暂缓区回退到指定版本

根据 $ git log --oneline 显示的版本号(下图黄色的字),可以回退到任何一个版本,也可通过 HEAD 来指定版本(下图红色的字)。

以旧图举例:

技术图片

Git --恢复修改的文件

标签:add   tom   更新   row   版本号   一个   ssis   org   git log   

原文地址:https://www.cnblogs.com/hustcser/p/10354712.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!