Git《二》时光机穿梭

Git<二>时光机穿梭

零、 目录

  1. 时光机
  2. 版本回退
  3. 工作区和暂存区
  4. 管理修改
  5. 撤销修改
  6. 删除文件
  7. 总结

一、 时光机

  1. 我们已经成功地添加并提交了一个readme.txt文件,现在,是时候继续工作了,于是,我们继续修改readme.txt文件,改成如下内容:

     Git is a distributed version control system.
     Git is free software.
    
  2. 现在,运行git status命令看看结果:

     [root@localhost learngit]# vim  readme.txt 
     [root@localhost learngit]#    git status 
     # 位于分支 master
     # 尚未暂存以备提交的变更:
     #   (使用 "git add ..." 更新要提交的内容)
     #   (使用 "git checkout -- ..." 丢弃工作区的改动)
     #
     #	修改:      readme.txt
     #
     修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
    
  3. git status命令可以让我们时刻掌握仓库当前的状态,上面的命令输出告诉我们,readme.txt被修改过了,但还没有准备提交的修改。

  4. 虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。比如你休假两周从国外回来,第一天上班时,已经记不清上次怎么修改的readme.txt,所以,需要用git diff这个命令看看:

     [root@localhost learngit]#  git diff readme.txt 
     diff --git a/readme.txt b/readme.txt
     index 9f7547c..b931b43 100644
     --- a/readme.txt
     +++ b/readme.txt
     @@ -1,2 +1,2 @@
     -Git is a version control system.
     -Git is free software.
     \ No newline at end of file
     +Git is a distrbuted version control system.
     +Git is free software.
    
  5. git diff顾名思义就是查看difference,显示的格式正是Unix通用的diff格式,可以从上面的命令输出看到,我们在第一行添加了一个distributed单词。知道了对readme.txt作了什么修改后,再把它提交到仓库就放心多了,提交修改和提交新文件是一样的两步,第一步是git add:

     [root@localhost learngit]# git add readme.txt 
     [root@localhost learngit]#   git commit -m '修改readme文件'
     [master 3152fb0] 修改readme文件	
      Committer: outman 
     您的姓名和邮件地址基于登录名和主机名进行了自动设置。请检查它们正确
     与否。您可以通过下面的命令对其进行明确地设置以免再出现本提示信息:
     
         git config --global user.name "Your Name"
         git config --global user.email [email protected]
     
     设置完毕后,您可以用下面的命令来修正本次提交所使用的用户身份:
     
         git commit --amend --reset-author
     
      1 file changed, 2 insertions(+), 2 deletions(-)
    
  6. 提交后,我们再用git status命令看看仓库的当前状态:

     [root@localhost learngit]# git status
     # 位于分支 master
     无文件要提交,干净的工作区
    

二、 版本回退

  1. 现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下:

     Git is a distributed version control system.
     Git is free software distributed under the GPL.
    
  2. 然后尝试提交:

     $ git add readme.txt
     $ git commit -m "append GPL"
     [master 1094adb] append GPL
      1 file changed, 1 insertion(+), 1 deletion(-)
    
  3. 像这样,你不断对文件进行修改,然后不断提交修改到版本库里,就好比玩RPG游戏时,每通过一关就会自动把游戏状态存盘,如果某一关没过去,你还可以选择读取前一关的状态。有些时候,在打Boss之前,你会手动存盘,以便万一打Boss失败了,可以从最近的地方重新开始。Git也是一样,每当你觉得文件修改到一定程度的时候,就可以“保存一个快照”,这个快照在Git中被称为commit。一旦你把文件改乱了,或者误删了文件,还可以从最近的一个commit恢复,然后继续工作,而不是把几个月的工作成果全部丢失。

  4. 现在,我们回顾一下readme.txt文件一共有几个版本被提交到Git仓库里了:

     版本1:write a readme file
     
     Git is a version control system.
     Git is free software.
     
     版本2:修改readme文件
     
     Git is a distributed version control system.
     Git is free software.
     
     版本3:修改readme文件
     
     Git is a distributed version control system.
     Git is free software distributed under the GPL.
    
  5. 当然了,在实际工作中,我们脑子里怎么可能记得一个几千行的文件每次都改了什么内容,不然要版本控制系统干什么。版本控制系统肯定有某个命令可以告诉我们历史记录,在Git中,我们用git log命令查看:

     [root@localhost learngit]# git log 
     commit 8988d6357b9124be95cc0f7cf19b9130b63afc8a
     Author: outman 
     Date:   Mon Jun 10 22:19:11 2019 +0800
     
         修改readme文件
     
     commit 3152fb05001f17cc2d10013052ef97d191c56ee4
     Author: outman 
     Date:   Mon Jun 10 22:09:01 2019 +0800
     
         修改readme文件
     
     commit 73143807d58f05b96c64588ccebede8338d76cc9
     Author: root 
     Date:   Mon Jun 10 21:44:01 2019 +0800
     
         writr a readme file
    
  6. git log命令显示从最近到最远的提交日志

  7. 如果嫌输出信息太多,看得眼花缭乱的,可以试试加上–pretty=oneline参数:

     [root@localhost learngit]#   git log --pretty=oneline
     8988d6357b9124be95cc0f7cf19b9130b63afc8a 修改readme文件
     3152fb05001f17cc2d10013052ef97d191c56ee4 修改readme文件
     73143807d58f05b96c64588ccebede8338d76cc9 writr a readme file
    
  8. 需要友情提示的是,你看到的一大串类似1094adb…的是commit id(版本号),和SVN不一样,Git的commit id不是1,2,3……递增的数字,而是一个SHA1计算出来的一个非常大的数字,用十六进制表示,而且你看到的commit id和我的肯定不一样,以你自己的为准。为什么commit id需要用这么一大串数字表示呢?因为Git是分布式的版本控制系统,后面我们还要研究多人在同一个版本库里工作,如果大家都用1,2,3……作为版本号,那肯定就冲突了。

  9. 每提交一个新版本,实际上Git就会把它们自动串成一条时间线。如果使用可视化工具查看Git历史,就可以更清楚地看到提交历史的时间线:

  10. 好了,现在我们启动时光穿梭机,准备把readme.txt回退到上一个版本

  11. 首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交1094adb…(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD,上上一个版本就是HEAD,当然往上100个版本写100个比较容易数不过来,所以写成HEAD~100。

  12. 现在,我们要把当前版本回退到上一个版本,就可以使用git reset命令:

    [root@localhost learngit]# git reset --hard HEAD^
    HEAD 现在位于 3152fb0 修改readme文件
    
  13. –hard参数有啥意义?这个后面再讲,现在你先放心使用。

  14. 查看readme.txt 文件内筒, 果然被还原了

    [root@localhost learngit]#   cat readme.txt 
    Git is a distrbuted version control system.
    Git is free software.
    
  15. 还可以继续回退到上一个版本write a readme file,不过且慢,然我们用git log再看看现在版本库的状态:

    [root@localhost learngit]#   git log 
    commit 3152fb05001f17cc2d10013052ef97d191c56ee4
    Author: outman 
    Date:   Mon Jun 10 22:09:01 2019 +0800
    
        修改readme文件
    
    commit 73143807d58f05b96c64588ccebede8338d76cc9
    Author: root 
    Date:   Mon Jun 10 21:44:01 2019 +0800
    
        writr a readme file
    
  16. 最新的那个版本append GPL已经看不到了!好比你从21世纪坐时光穿梭机来到了19世纪,想再回去已经回不去了,肿么办?

  17. 办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个修改readme文件的commit id是1094adb…,于是就可以指定回到未来的某个版本:

    [root@localhost learngit]#  git reset --hard 8988d63
    HEAD 现在位于 8988d63 修改readme文件
    [root@localhost learngit]#   git log --pretty=oneline
    8988d6357b9124be95cc0f7cf19b9130b63afc8a 修改readme文件
    3152fb05001f17cc2d10013052ef97d191c56ee4 修改readme文件
    73143807d58f05b96c64588ccebede8338d76cc9 writr a readme file
    
  18. 版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。

  19. Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针,当你回退版本的时候,Git仅仅是把HEAD从指向修改readme文件:

    ┌────┐
    │HEAD│
    └────┘
       │
       └──> ○ 修改readme文件2
            │
            ○ 修改readme文件1
            │
            ○ write a readme file
    
  20. 改为指向修改readme文件1:

    ┌────┐
    │HEAD│
    └────┘
       │
       │    ○ 修改readme文件2
       │    │
       └──> ○ 修改readme文件1
            │
            ○ write a readme file
    
  21. 然后顺便把工作区的文件更新了。所以你让HEAD指向哪个版本号,你就把当前版本定位在哪。

  22. 现在,你回退到了某个版本,关掉了电脑,第二天早上就后悔了,想恢复到新版本怎么办?找不到新版本的commit id怎么办?

  23. 在Git中,总是有后悔药可以吃的。当你用$ git reset --hard HEAD^回退到修改readme文件1版本时,再想恢复到修改readme文件2,就必须找到修改readme文件2的commit id。Git提供了一个命令git reflog用来记录你的每一次命令:

    [root@localhost learngit]#     git reflog
    8988d63 HEAD@{0}: reset: moving to 8988d63
    3152fb0 HEAD@{1}: reset: moving to HEAD^
    8988d63 HEAD@{2}: commit: 修改readme文件
    3152fb0 HEAD@{3}: commit: 修改readme文件
    7314380 HEAD@{4}: commit (initial): writr a readme file
    

三、 工作区和暂存区

  1. Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。

  2. 工作区(Working Directory):

    1. 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区:
  3. 版本库(Repository):

    1. 工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
  4. Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

  5. 分支和HEAD的概念我们以后再讲。

  6. 前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:

    1. 第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
    2. 第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
  7. 因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。

  8. 你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

  9. 俗话说,实践出真知。现在,我们再练习一遍,先对readme.txt做个修改,比如加上一行内容:

     Git is a distributed version control system.
     Git is free software distributed under the GPL.
     Git has a mutable index called stage.
    
  10. 然后,在工作区新增一个LICENSE文本文件(内容随便写)。

  11. 先用git status查看一下状态:

     [root@localhost learngit]#    git status 
     # 位于分支 master
     # 尚未暂存以备提交的变更:
     #   (使用 "git add ..." 更新要提交的内容)
     #   (使用 "git checkout -- ..." 丢弃工作区的改动)
     #
     #	修改:      readme.txt
     #
     # 未跟踪的文件:
     #   (使用 "git add ..." 以包含要提交的内容)
     #
     #	LICENSE.txt
     修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
    
  12. Git非常清楚地告诉我们,readme.txt被修改了,而LICENSE还从来没有被添加过,所以它的状态是Untracked。

  13. 现在,使用两次命令git add,把readme.txt和LICENSE都添加后,用git status再查看一下:

     [root@localhost learngit]#   git add readme.txt 
     [root@localhost learngit]#  git add LICENSE.txt 
     [root@localhost learngit]#  git status
     # 位于分支 master
     # 要提交的变更:
     #   (使用 "git reset HEAD ..." 撤出暂存区)
     #
     #	新文件:    LICENSE.txt
     #	修改:      readme.txt
     #
    
  14. 现在,暂存区的状态就变成这样了:

  15. 所以,git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。

    [root@localhost learngit]#  git commit -m 'understand how stage work'
    [master 3131157] understand how stage work
     Committer: outman 
    您的姓名和邮件地址基于登录名和主机名进行了自动设置。请检查它们正确
    与否。您可以通过下面的命令对其进行明确地设置以免再出现本提示信息:
    
        git config --global user.name "Your Name"
        git config --global user.email [email protected]
    
    设置完毕后,您可以用下面的命令来修正本次提交所使用的用户身份:
    
        git commit --amend --reset-author
    
     2 files changed, 2 insertions(+)
     create mode 100644 LICENSE.txt
    
  16. 一旦提交后,如果你又没有对工作区做任何修改,那么工作区就是“干净”的:

    [root@localhost learngit]#   git status 
    # 位于分支 master
    无文件要提交,干净的工作区
    

四、 管理修改

  1. 现在,假定你已经完全掌握了暂存区的概念。下面,我们要讨论的就是,为什么Git比其他版本控制系统设计得优秀,因为Git跟踪并管理的是修改,而非文件。

  2. 你会问,什么是修改?比如你新增了一行,这就是一个修改,删除了一行,也是一个修改,更改了某些字符,也是一个修改,删了一些又加了一些,也是一个修改,甚至创建一个新文件,也算一个修改。

  3. 为什么说Git管理的是修改,而不是文件呢?我们还是做实验。第一步,对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.
    
  4. 然后添加 git add:

     [root@localhost learngit]#   git add readme.txt 
     [root@localhost learngit]#  git status
     # 位于分支 master
     # 要提交的变更:
     #   (使用 "git reset HEAD ..." 撤出暂存区)
     #
     #	修改:      readme.txt
     #
    
  5. 然后在修改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.
    
  6. 提交

     [root@localhost learngit]#  git commit -m 'git tracks change'
     [master 7b349e2] git tracks change
      Committer: outman 
     您的姓名和邮件地址基于登录名和主机名进行了自动设置。请检查它们正确
     与否。您可以通过下面的命令对其进行明确地设置以免再出现本提示信息:
     
         git config --global user.name "Your Name"
         git config --global user.email [email protected]
     
     设置完毕后,您可以用下面的命令来修正本次提交所使用的用户身份:
     
         git commit --amend --reset-author
     
      1 file changed, 1 insertion(+)
    
  7. 查看状态

     [root@localhost learngit]#   git status 
     # 位于分支 master
     # 尚未暂存以备提交的变更:
     #   (使用 "git add ..." 更新要提交的内容)
     #   (使用 "git checkout -- ..." 丢弃工作区的改动)
     #
     #	修改:      readme.txt
     #
     修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
    
  8. 咦,怎么第二次的修改没有被提交?

  9. 别激动,我们回顾一下操作过程:

    1. 第一次修改 -> git add -> 第二次修改 -> git commit
  10. 你看,我们前面讲了,Git管理的是修改,当你用git add命令后,在工作区的第一次修改被放入暂存区,准备提交,但是,在工作区的第二次修改并没有放入暂存区,所以,git commit只负责把暂存区的修改提交了,也就是第一次的修改被提交了,第二次的修改不会被提交。

  11. 提交后,用git diff HEAD – readme.txt命令可以查看工作区和版本库里面最新版本的区别:

    [root@localhost learngit]#  git diff HEAD -- readme.txt 
    diff --git a/readme.txt b/readme.txt
    index e93cf38..b39f9d1 100644
    --- a/readme.txt
    +++ b/readme.txt
    @@ -1,4 +1,4 @@
     Git is a distributed version control system.
     Git is free software distributed under the GPL.
     Git has a mutable index called stage.
    -Git tranks change.
    +Git tranks changes of file.
    
  12. 那怎么提交第二次修改呢?你可以继续git add再git commit,也可以别着急提交第一次修改,先git add第二次修改,再git commit,就相当于把两次修改合并后一块提交了:

五、 撤销修改

  1. 自然,你是不会犯错的。不过现在是凌晨两点,你正在赶一份工作报告,你在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.
    
  2. 在你准备提交前,一杯咖啡起了作用,你猛然发现了stupid boss可能会让你丢掉这个月的奖金!

  3. 既然错误发现得很及时,就可以很容易地纠正它。你可以删掉最后一行,手动把文件恢复到上一个版本的状态。如果用git status查看一下:

     [root@localhost learngit]#    git status
     # 位于分支 master
     # 尚未暂存以备提交的变更:
     #   (使用 "git add ..." 更新要提交的内容)
     #   (使用 "git checkout -- ..." 丢弃工作区的改动)
     #
     #	修改:      readme.txt
     #
     修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
    
  4. 你可以发现,Git会告诉你,git checkout – file可以丢弃工作区的修改:

     [root@localhost learngit]#   git checkout -- readme.txt 
     [root@localhost learngit]#  git status
     # 位于分支 master
     无文件要提交,干净的工作区
    
  5. 命令git checkout – readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:

    1. 一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
    2. 一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
  6. 总之,就是让这个文件回到最近一次git commit或git add时的状态。

  7. git checkout – file命令中的–很重要,没有–,就变成了“切换到另一个分支”的命令,我们在后面的分支管理中会再次遇到git checkout命令。

  8. 现在假定是凌晨3点,你不但写了一些胡话,还git add到暂存区了:

     [root@localhost learngit]# cat readme.txt 
     t 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.
     [root@localhost learngit]# git add readme.txt 
    
  9. 庆幸的是,在commit之前,你发现了这个问题。用git status查看一下,修改只是添加到了暂存区,还没有提交:

     [root@localhost learngit]# git status 
     # 位于分支 master
     # 要提交的变更:
     #   (使用 "git reset HEAD ..." 撤出暂存区)
     #
     #	修改:      readme.txt
     #
    
  10. Git同样告诉我们,用命令git reset HEAD 可以把暂存区的修改撤销掉(unstage),重新放回工作区:

    [root@localhost learngit]#   git reset HEAD readme.txt 
    重置后撤出暂存区的变更:
    M	readme.txt
    
  11. git reset命令既可以回退版本,也可以把暂存区的修改回退到工作区。当我们用HEAD时,表示最新的版本。

  12. 再用git status查看一下,现在暂存区是干净的,工作区有修改:

    [root@localhost learngit]# git status 
    # 位于分支 master
    # 尚未暂存以备提交的变更:
    #   (使用 "git add ..." 更新要提交的内容)
    #   (使用 "git checkout -- ..." 丢弃工作区的改动)
    #
    #	修改:      readme.txt
    #
    修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
    
  13. 还记得如何丢弃工作区的修改吗?

    [root@localhost learngit]#   git checkout -- readme.txt 
    [root@localhost learngit]#  git status 
    # 位于分支 master
    无文件要提交,干净的工作区
    
  14. 现在,假设你不但改错了东西,还从暂存区提交到了版本库,怎么办呢?还记得版本回退一节吗?可以回退到上一个版本。不过,这是有条件的,就是你还没有把自己的本地版本库推送到远程。还记得Git是分布式版本控制系统吗?我们后面会讲到远程版本库,一旦你把stupid boss提交推送到远程版本库,你就真的惨了……

六、 删除文件

  1. 在Git中,删除也是一个修改操作,我们实战一下,先添加一个新文件test.txt到Git并且提交:

     [root@localhost learngit]# touch test.txt 
     [root@localhost learngit]# git add test.txt 
     [root@localhost learngit]#   git commit -m 'commit test.txt'
     [master ff7afa5] commit test.txt
      Committer: outman 
     您的姓名和邮件地址基于登录名和主机名进行了自动设置。请检查它们正确
     与否。您可以通过下面的命令对其进行明确地设置以免再出现本提示信息:
     
         git config --global user.name "Your Name"
         git config --global user.email [email protected]
     
     设置完毕后,您可以用下面的命令来修正本次提交所使用的用户身份:
     
         git commit --amend --reset-author
     
      1 file changed, 0 insertions(+), 0 deletions(-)
      create mode 100644 test.txt
    
  2. 一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm命令删了:

     [root@localhost learngit]# ls
     LICENSE.txt  readme.txt  test.txt
     [root@localhost learngit]# rm test.txt 
     rm:是否删除普通空文件 "test.txt"?y
     [root@localhost learngit]# ls
     LICENSE.txt  readme.txt
    
  3. 这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻告诉你哪些文件被删除了:

     [root@localhost learngit]#   git status 
     # 位于分支 master
     # 尚未暂存以备提交的变更:
     #   (使用 "git add/rm ..." 更新要提交的内容)
     #   (使用 "git checkout -- ..." 丢弃工作区的改动)
     #
     #	删除:      test.txt
     #
     修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
    
  4. 现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:

     [root@localhost learngit]#  git rm test.txt
     rm 'test.txt'
     [root@localhost learngit]#  git commit -m 'rm test.txt'
     [master 653be07] rm test.txt
      Committer: outman 
     您的姓名和邮件地址基于登录名和主机名进行了自动设置。请检查它们正确
     与否。您可以通过下面的命令对其进行明确地设置以免再出现本提示信息:
     
         git config --global user.name "Your Name"
         git config --global user.email [email protected]
     
     设置完毕后,您可以用下面的命令来修正本次提交所使用的用户身份:
     
         git commit --amend --reset-author
     
      1 file changed, 0 insertions(+), 0 deletions(-)
      delete mode 100644 test.txt
    
  5. 另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:

     [root@localhost learngit]# ls
     LICENSE.txt  readme.txt  test.txt
     [root@localhost learngit]# rm -rf test.txt 
     [root@localhost learngit]# ls
     LICENSE.txt  readme.txt
     [root@localhost learngit]# git checkout -- test.txt 
     [root@localhost learngit]#  ls
     LICENSE.txt  readme.txt  test.txt
    

七、 总结

时光机总结:

  1. 要随时掌握工作区的状态,使用git status命令。
  2. 如果git status告诉你有文件被修改过,用git diff可以查看修改内容

版本回退总结:

  1. HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。
  2. 穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
  3. 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

工作区和暂存区总结:

  1. 暂存区是Git非常重要的概念,弄明白了暂存区,就弄明白了Git的很多操作到底干了什么。

管理修改总结:

  1. 现在,你又理解了Git是如何跟踪修改的,每次修改,如果不用git add到暂存区,那就不会加入到commit中。

撤销修改总结:

  1. 场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file。
  2. 场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD ,就回到了场景1,第二步按场景1操作。
  3. 场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

删除文件总结:

  1. 命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。

你可能感兴趣的:(Git)