深入了解git的checkout命令

检出命令(git checkout)是Git最常用的命令之一,同时也是一个很危险的命令.

因为这条命令会重写工作区.检出命令的用法如下:

用法一: git checkout [-q] [<commit>] [--] <path>...

用法二: git checkout [<branch>]

用法三: git checkout [-m] [[-b|--orphan] <new_branch>] [<start_point>>]

第一种用法的<commit>是可选项,如果省略则相当于从暂存区(index)进行检出.

这和之前的重置命令大不相同:重置的默认值是HEAD,而检出的默认值是暂存区.

因此重置一般用于重置暂存区(除非使用--hard参数,否则不重置工作区)

而检出命令主要是覆盖工作区(如果<commit>不省略,也会替换暂存区中相应的文件).

第一种用法:

先来合个影:

在Git中,"留影"用的命令是叫做tag,更加专业的术语叫做"里程碑"(打tag,或者打标签)

"留影"的命令如下:

$ git tag -m "say bye to previous"  old_practice

只需要知道里程碑也无非是一个引用.通过记录提交ID(或者创建Tag对象)来为当前版本库的状态进行"留影"

$ ls .git/refs/tags/old_practice

留影之后,可以执行git describe命令将最新提交显示为一个容易记忆的名字.

显示的时候会选取离该提交最近的里程碑作为"基础版本号",后面附加标识距离"基础版本"

的数字,以及该提交的SHA1哈希值的缩写.因为最新的提交上恰好被打了一个"里程碑".

所以直接显示"里程碑"的名称.这个技术会在后面的示例代码中经常用到.

删除文件:(这个时候工作区只有一个test1.txt文件是已经commit结束,又增加了新的东西,处于modify状态)

在这个暂存区和工作区都包含文件修改的情况下,使用删除命令更具有挑战性.

删除命令有很多种使用方法,有的方法很巧妙,而有的方法则需要更多的输入.

为了分别介绍不同的删除方法.还要使用之前使用过的保存进度的git stash 命令.

保存进度:

在恢复进度.注意不要使用git stash pop ,而是使用git stash apply,因为这个保存的进度要被多次用到.

本地删除不是真的删除.

$ls是看工作区中有哪些文件.

$rm test1.txt 命令执行之后,工作区中处于修改Modified状态的test1.txt文件被删除了.

但是执行$ git ls-files 之后还是可以看出有文件的.

从文件的状态来看,文件只是在本地进行了删除,尚未添加到暂存区(提交任务)中.

也就是说:直接在工作区删除,对暂存区和版本库没有任何影响.

从Git的状态中可以看出,本地删除如果要反应在暂存区中应该用git rm命令,对不向删除的文件执行

git checkout -- <file>,可以让文件在工作区中重现.

这个时候如果用checkout命令的话,刚才已经"被删除"的test1.txt就会恢复在工作区了.

不过这个文件是没有修改之前的状态.上面的图中我也已经$git status 了.

执行git rm命令删除文件

$ git rm test1.txt
这样删除的动作加入了暂存区,这时执行提交动作,就从真正意义上执行了文件删除.

$ git commit -m "delete files(using:git rm)"

不过不要担心,文件只是在版本库的最新提交中被删除了,在历史提交中尚在.可以通过下面的命令查看历史版本的文件列表.

$ git ls-files --with-tree=HEAD^

也可以查看在历史版本中尚在的删除文件的内容.

$git cat-file -p HEAD^:test1.txt

命令git add -u 快速标记删除

在前面执行git rm命令时,写下了所有要删除的文件名,很长.能不能简化些?

实际上git add就可以.即使用-u参数调用git add命令.含义是将本地有改动(包括修改和删除)的文件标记到暂存区.

为了重现刚才的场景,先使用重置命令抛弃最新的提交,再使用进度回复到之前的状态.

文件的整个过程操作:

上图中$git stash apply -q 恢复保存的进度(参数-q 使得命令进入安静模式)

执行完上面这个命令恢复到了在test1.txt的modified状态.

执行 git add -u 命令可以将(被版本库追踪的)本地文件的变更(修改,删除)全部记录到暂存区中.

关于Git中的一些常用的命令的更多相关文章

  1. 图解git中的最常用命令

    图解git中的最常用命令 Git命令参考手册(文本版) git init                                                  # 初始化本地git仓库(创 ...

  2. git中常见的几个命令

    git中常见的几个命令 本地仓库 三个区域 工作目录 暂存区 本地仓库 文件的四个状态 未跟踪 untracked 已暂存 staged 已提交commited 已修改 modified 基本命令 g ...

  3. mac中一一些常用的命令

    本文转载至 http://blog.csdn.net/chen505358119/article/details/9244701   这里主要讲的是mac中的一些命令,怕忘记了所以记在这里. 1.首先 ...

  4. git操作分支的常用的命令

    查看所有的分支:                 git branch -a 查看当前所在的分支:          git branch 检出分支:                          ...

  5. git中通过实际操作来了解常用命令

    基本的6个命令 常用的就下面6个命令,但是详细的可能有上百个命令. 还需要特别了解git的几个名词,workspace:工作区,Index/Stage:暂存区,Respository:本地仓库,Rem ...

  6. GIT中常用的命令

    最近项目中使用到了GIT,所以记录一下GIT中常用的命令. GIT使用的客户端有Git Bash:http://code.google.com/p/msysgit/ 还有乌龟TortoiseGit:h ...

  7. 总结下git中一些常用命令

    一.目录操作 1.cd 即change directory,改变目录,如 cd d:/www,切换到d盘的www目录. 2.cd .. cd+空格+两个点,回退到上一目录. 3.pwd 即 print ...

  8. Git 中的一些其他常用命令

    1.查看提交的历史版本(git log) 我们可以使用 git log 命令来查看提交的历史版本. 默认不用任何参数的话,git log 会按提交时间列出所有的更新,最近的更新排在最上面.每个版本都有 ...

  9. git常用的命令集合

    Git 是一个很强大的分布式版本控制系统.它不但适用于管理大型开源软件的源代码,管理私人的文档和源代码也有很多优势. Git常用操作命令: 1) 远程仓库相关命令 检出仓库:$ git clone g ...

随机推荐

  1. 【DOM】1.DOM优化

    1.JS include :DOM BOM ECMA 2.Browser 分别独立实现dom & JS as if two isolated islands 3.JS操作DOM from th ...

  2. KMP算法详解 --从july那学的

    KMP代码: int KmpSearch(char* s, char* p) { ; ; int sLen = strlen(s); int pLen = strlen(p); while (i &l ...

  3. uva 11916 Emoogle Grid

    题意:用K种颜色给一个N*M的格子涂色.其中有B个格子是不能涂色的.涂色时满足同一列上下紧邻的两个格子的颜色不同.所有的涂色方案模100000007后为R.现在给出M.K.B.R,求一个最小的N,满足 ...

  4. SQL Server Cpu 100% 的常见原因及优化

    SQL Server Cpu 100% 的情况并不太常见,一般引起 SQL Server 产生性能问题的,都是 阻塞.连接数.IO 磁盘等.所以,一般SQL Server 的使用率都是比较低的.但是, ...

  5. ./wls1036_linux32.bin: /lib/ld-linux.so.2: bad ELF interpreter

    [CentOS]安装软件:/lib/ld-linux.so.2: bad ELF interpreter解决   环境: [orangle@localhost Downloads]$ uname -m ...

  6. CodeForces 696A(Lorenzo Von Matterhorn ) & CodeForces 696B(Puzzles )

    A,给一棵完全二叉树,第一个操作,给两个点,两点路径上的所有边权值都增加w,第二个操作,给两个点,求两点路径上的所有边权值和. 我看一眼题就觉得是树链剖分,而我又不会树链剖分,扔掉. 后来查了题解,首 ...

  7. 软件开发中的单一职责(转至INFOQ)

    最近在实践微服务化过程中,对其“单一职责”原则深有体会.那么只有微服务化才可以单一职责,才可以解耦吗?答案是否定的. 单一职责原则是这样定义的:单一的功能,并且完全封装起来. 我们做后端Java开发的 ...

  8. STC12C5A60S2片内存储器介绍

    STC12C5A60S2内部集成RAM 1280字节,其中 内部RAM(data):256 Byte 内部扩展RAM(xdata):1024 Byte 支持片外扩展RAM: 64kB STC12C5A ...

  9. [置顶] HTML语义和前端架构

    关于语义学 语义学是研究符号和意义之间的关系以及它们表示的内容.在语言学中,则主要是研究符号(例如单词,短语或者语音)在语言中所表达的意义.而在前端开发时,语义学则更多的关注HTML元素,属性以及它的 ...

  10. SignalTap II逻辑分析仪的使用

    一.例子 我们使用如图1所示的verilog代码所实现的开关电路作为例子.这个电路把DE系列开发板上的前8个开关简单的和对应的8个红色LED相连接.它是这样工作的:在时钟(CLOCK_50)的上升沿读 ...