Git教程(5)- 撤销修改和删除文件操作

2020年8月24日16:08:53 评论 51

一:撤销修改:

    比如我现在在readme.txt文件里面增加一行 内容为555555555555,我们先通过命令查看如下:

Git教程(5)- 撤销修改和删除文件操作

在我未提交之前,我发现添加5555555555555内容有误,所以我得马上恢复以前的版本,现在我可以有如下几种方法可以做修改:

第一:如果我知道要删掉哪些内容的话,直接手动更改去掉那些需要的文件,然后add添加到暂存区,最后commit掉。

第二:我可以按以前的方法直接恢复到上一个版本。使用 git reset  --hard HEAD^

但是现在我不想使用上面的2种方法,我想直接想使用撤销命令该如何操作呢?首先在做撤销之前,我们可以先用 git status 查看下当前的状态。如下所示:

Git教程(5)- 撤销修改和删除文件操作

可以发现,Git会告诉你,git checkout  -- file 可以丢弃工作区的修改,如下命令:

git checkout  --  readme.txt,如下所示:

Git教程(5)- 撤销修改和删除文件操作

命令 git checkout -- readme.txt 意思就是,把readme.txt文件在工作区做的修改全部撤销,这里有2种情况,如下:

  1. readme.txt自动修改后,还没有放到暂存区,使用 撤销修改就回到和版本库一模一样的状态。
  2. 另外一种是readme.txt已经放入暂存区了,接着又作了修改,撤销修改就回到添加暂存区后的状态。

对于第二种情况,我想我们继续做demo来看下,假如现在我对readme.txt添加一行 内容为6666666666666,我git add 增加到暂存区后,接着添加内容7777777,我想通过撤销命令让其回到暂存区后的状态。如下所示:

  Git教程(5)- 撤销修改和删除文件操作

注意:命令git checkout -- readme.txt 中的 -- 很重要,如果没有 -- 的话,那么命令变成创建分支了。

二:删除文件。

     假如我现在版本库testgit目录添加一个文件b.txt,然后提交。如下:

  Git教程(5)- 撤销修改和删除文件操作

如上:一般情况下,可以直接在文件目录中把文件删了,或者使用如上rm命令:rm b.txt ,如果我想彻底从版本库中删掉了此文件的话,可以再执行commit命令 提交掉,现在目录是这样的,

 Git教程(5)- 撤销修改和删除文件操作

只要没有commit之前,如果我想在版本库中恢复此文件如何操作呢?

可以使用如下命令 git checkout  -- b.txt,如下所示:

Git教程(5)- 撤销修改和删除文件操作

再来看看我们testgit目录,添加了3个文件了。如下所示:

Git教程(5)- 撤销修改和删除文件操作


继续阅读:Git教程

Git教程(1)- 简介和安装
Git教程(2)- 创建版本库
Git教程(3)- 版本回退
Git教程(4)- 理解工作区与暂存区的区别
Git教程(5)- 撤销修改和删除文件操作
Git教程(6)- 操作远程仓库
Git教程(7)- 创建与合并分支
Git教程(8)- bug分支
Git教程(9)- 多人协作
Git教程(10)- Git基本常用命令
Git教程(11)- Git命令图解剖析(进阶)

回到目录页Git教程 - 目录

(转载自:https://www.cnblogs.com/tugenhua0707/p/4050072.html)

素课网
  • 本文由 发表于 2020年8月24日16:08:53
  • 转载请注明:https://www.suketech.com/9412.html
Git教程(10)- Git基本常用命令 Git教程

Git教程(10)- Git基本常用命令

我每天使用 Git ,但是很多命令记不住。 一般来说,日常使用只要记住下图6个命令,就可以了。但是熟练使用,恐怕要记住60~100个命令。 下面是我整理的常用 Git 命令清单。几个专用名词的译名如下...
Git教程(9)- 多人协作 Git教程

Git教程(9)- 多人协作

当你从远程库克隆时候,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且远程库的默认名称是origin。 要查看远程库的信息 使用 git remote 要查看远程库的详...
Git教程(8)- bug分支 Git教程

Git教程(8)- bug分支

在开发中,会经常碰到bug问题,那么有了bug就需要修复,在Git中,分支是很强大的,每个bug都可以通过一个临时分支来修复,修复完成后,合并分支,然后将临时的分支删除掉。 比如我在开发中接到一个40...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: