使用Git,您如何发现当前版本和上一版本之间的差异?

git diff last version:HEAD

当前回答

如果HEAD指向顶部提交,则可以执行以下操作:

commit1 -> HEAD
commit2 -> HEAD~1
commit3 -> HEAD~2

第一次和第二次提交之间的差异:

git diff HEAD~1 HEAD

第一次和第三次提交之间的差异:

git diff HEAD~2 HEAD

第二次和第三次提交之间的差异:

git diff HEAD~2 HEAD~1

等等

其他回答

如果已添加但尚未提交,请使用缓存标志:

git diff --cached --color

最后一次提交与上次提交之间的差异(加上当前状态,如果有):

git diff HEAD~

甚至(更容易打字)

git diff @~

其中@是当前分支HEAD的同义词,~表示“给我提到的修订的父级”。

你也可以这样做:

与上一次提交进行比较

git diff --name-status HEAD~1..HEAD

与当前和前两次提交进行比较

git diff --name-status HEAD~2..HEAD

如果希望对最后n次提交进行更改,可以使用以下选项:

git diff HEAD~n

因此,对于当前提交的最后5次提交(包括当前提交在内的计数),将是:

git diff HEAD~5

假设“当前版本”是工作目录(未提交修改),“最后版本”是HEAD(当前分支的最后提交修改)

git diff HEAD

以下内容归功于用户Cerran。

如果在提交时总是使用-a跳过临时区域,那么可以简单地使用gitdiff。

总结

gitdiff显示未分页的更改。gitdiff——缓存显示分段更改。git diff HEAD显示所有更改(暂存和未暂存)。

来源:git diff(1)手册页–Cerran