• Git 基础再学习之:git checkout -- file


    首先明白一下基本概念和用法,这段话是从前在看廖雪峰的git教程的时候摘到OneNote的

    准备工作:

    • 新建了一个learngit文件夹,在bash中cd进入文件夹,用以下命令创建一个仓库。
    $ git init
    • 添加一个文本文件one.txt,里面写个内容 "one"。准备工作完成。文件夹情况如下:

       

    实验开始:

    实验一:没有add,没有commit

    • 此时不对文件做任何提交,用git status 查看一下文件状态:

        

        说明是完全没有 git add 的

    • 进入文件夹,把文本文件 one.txt 中的内容加一行 “Two”。
    • 回到bash窗口,尝试用 git checkout -- file 命令恢复状态,结果报错:

        

        说明没有add,还想checkout,没有什么意义可言,因为既不在暂存区,也没有提交,所以就没有所谓的恢复

    实验二:有add,但不commit

    • 用 git add 把 文本文件添加到暂存区:

        

    • 进入文件夹,把文本文件 one.txt 中的内容加一行 “Two”。
    • 回到bash窗口,尝试用 git checkout -- file 命令恢复状态,啥也没报。Unix哲学是没有情况就是好情况。
    • 打开 one.txt ,发现添加的那一行没了,内容中又只剩下 "One"

    实验三:add又commit

    • 确认一下:现在文本文件中内容是一行 "One",因为之前已经 add 过了,所以先用如下命令让状态恢复到连 add 也没有过的时候
    git rm --cached one.txt

        效果会是这样的:

        

        好,又恢复到了没有add的情况。

    • 然后我们从头开始 - -。。。其实我也不知道为啥要这样,感觉和前面步骤相同比较好一点。。
    • 用 git add 添加,然后用 git commit 提交,结果如下:成功提交

        

       这时候,文本文件中只有一行"One",

    • 进入文件夹,把文本文件 one.txt 中的内容加一行 “Two”。出现如下界面(说明修改过了)

        

    • 回到bash窗口,尝试用 git checkout -- file 命令恢复状态,啥也没报。Unix哲学是没有情况就是好情况。
    • 打开 one.txt ,发现添加的那一行没了,内容中又只剩下 "One"

    结论:必须要先add才存在恢复一说。 checkout 可以理解为“切回某个文件”的意思。但是要注意,这个命令是对工作区生效的。

  • 相关阅读:
    opencv入门踩坑之路(一)
    编写vue的时候(html也一样),限制一个div内可显示的字数
    win10开机后内存占用非常高,但是资源管理器显示的进程占用得很少,可以考虑更新驱动
    java 随机数产生 常用类及方法
    你不会的是这个正则表达式吗?
    系统编程第三次上机
    Java第三次上机随笔
    系统编程第二次实验
    Java第二次上机随笔
    面向对象-Java MOOC翁恺老师第一次作业
  • 原文地址:https://www.cnblogs.com/Calvino/p/5930656.html
Copyright © 2020-2023  润新知