本文共 2268 字,大约阅读时间需要 7 分钟。
HEAD 表示当前版本,也就是最新的提交。上一个版本就是 HEAD^ ,上上一个版本就是 HEAD^^ ,
往上100个版本写100个 “ ^ ” 比较容易数不过来,所以写成 HEAD~100 。HEAD~2 相当于 HEAD^^ 。我们在 可以利用 HEAD 关键字进行指定版本的回退。
那么对于 $ git diff HEAD -- <filename> 命令是不是也能操作不同的情况?
自己试了试一个例子:
命令 $ git diff 查看对比两次文件内容具体修改了什么。
命令 $ git diff HEAD -- <filename> (“--”前后有空格),可以查看工作区和版本库里面最新版本的区别。
步骤:最后文件内容为:
执行 $ git diff <filename> 命令,命令行窗口不会输出文件的改动信息。
执行 $ git diff HEAD -- <filename> 命令同样也不会输出文件的改动信息。因为当前工作区未做改动。
执行 $ git diff HEAD^ -- <filename> 命令则可以查看最近两次提交版本的区别(版本E和版本D的差别——增加数字“5”)
执行 $ git diff HEAD^^ -- <filename> 命令则可以查看最近一次提交和最近一次提交的上上个版本的区别(版本E和版本C的差别——增加数字“4”和“5”)
执行 $ git diff HEAD^^^ -- <filename> 命令则可以查看版本E和版本B的差别——增加数字“3”,“4”和“5”。
执行 $ git diff HEAD~4 -- <filename> 命令则可以查看版本E和版本A的差别——增加数字“2”,“3”,“4”和“5”。等同于HEAD^^^^
现在增加第六步:再增加数字“6”。分三种情况,还未执行 add、add 后还未commit、add 并commit(版本F)。
此时执行 $ git diff <filename> 命令,可以查看对比最近一次提交的版本,刚刚在工作区修改了什么内容(工作区和版本E的差别——增加数字“6”)。
同样执行 $ git diff HEAD -- <filename> 命令,也可以查看对比最近一次提交的版本,刚刚工作区修改了什么内容——增加数字“6”。
如果执行 $ git diff HEAD^ -- <filename> 则会显示工作区与仓库里最近一次提交的上一次提交的版本的改动信息(工作区和版本D的差别——增加数字“5”和“6”)。
如果执行 $ git diff HEAD^^ -- <filename> 则会显示工作区与仓库里最近一次提交的上两次提交的版本的改动信息(工作区和版本C的差别——增加数字“4”,“5”和“6”)。
依次类推。。
此时执行 $ git diff <filename> 命令。命令行窗口不会输出文件的改动信息。
而执行 $ git diff HEAD -- <filename> 命令则可以查到工作区与最近一次提交的版本库里面的区别(工作区和版本E的差别——增加数字“6”)。
以此类推。。
此时执行$ git diff <filename> 命令和 $ git diff HEAD -- <filename> 命令,窗口都不会输出文件的改动信息。
而执行 $ git diff HEAD^ -- <filename> 命令则可以查看最近两次提交版本的区别,以此类推。即该情况同上述在都已提交的情况下相同,不做赘述。
总结: 对于 $ git diff <filename> 、$ git diff HEAD -- <filename> 、 $ git diff HEAD^ -- <filename> (包括HEAD^^、HEAD^^^、以及以此类推 HAED~number)这三种命令,
在都已提交的版本库中。如果想查看其中两个提交都修改了哪些内容。可以使用 $ git diff HEAD^ -- <filename> 命令开始查看。以此类推。(即从 HEAD^ 开始便可以了,)
在工作区改动后,还未执行add命令的时候,命令 $ git diff <filename> 和 命令 $ git diff HEAD -- <filename> 两个都可以查看当前工作区和最近一次提交的版本之间的差别。以此类推 HEAD^^、HEAD^^^ 等可以查看当前工作区与之前指定某版本的差别。所以当我们在工作区修改过还没有添加都暂缓区的时候可以用这些命令查看刚刚在工作区改动了哪里。
而工作区改动后并且 执行add 命令后但还未提交, $ git diff <filename> 将不能再进行比较。但可以继续用关键词HEAD、HEAD^ 等进行比较。以此类推。