我在Ubuntu 10.04 (Lucid Lynx)上使用Git。

我已经向我的主人许下了一些承诺。

但是,我想知道这些提交之间的区别。它们都在我的主分支上。

例如:

commit dj374
made changes

commit y4746
made changes

commit k73ud
made changes

我想知道k73ud和dj374的区别。然而,当我执行以下操作时,我无法看到我在k73ud中所做的更改。

git diff k73ud..dj374 > master.patch

当前回答

检查pull后最后2次提交的更改最简单:

git diff HEAD~2 

其他回答

Try

git diff k73ud^..dj374

确保将k73ud的所有变化都包含在结果差异中。

Git diff比较两个端点(而不是提交范围)。 因为OP想要看到k73ud引入的变化,他/她需要区分k73ud的第一个父提交:k73ud^(或k73ud^1或k73ud~)。

这样,差异结果将包括自k73ud父节点以来的更改(意味着包括来自k73ud本身的更改),而不是自k73ud以来引入的更改(直到dj374)。

你也可以试试:

git diff oldCommit..newCommit
git diff k73ud..dj374 

And(1个空格,不是更多):

git diff oldCommit newCommit
git diff k73ud dj374

如果你只需要获取文件名(例如手动复制修补它们):

git diff k73ud dj374 --name-only

你可以将更改应用到另一个分支:

git diff k73ud dj374 > my.patch
git apply my.patch

下面的命令在Ubuntu 20.04和git v2.25.1上完美地工作:

git diff <base-commit-id> <target-commit-id>

对于最后两次提交

git diff HEAD~1 HEAD

通过扩展来比较2个提交,例如

git diff HEAD~6 HEAD~3

如果您想查看每次提交时引入的更改,请尝试"git log -p"

我总是喜欢使用命令行和用户友好的工具(GUI)在我的手中。两全其美。下面是我如何比较Git中的两次提交。

您可以显示两次提交之间的差异,如下所示。

在文本编辑器中编辑git配置文件:

git config --global -e 

在Git配置文件中设置一个合适的diff工具(用户友好),就像Windows中的Meld一样:

[difftool "meld"]
cmd = "C:/Program Files (x86)/Meld/Meld.exe" "LOCAL\" \"REMOTE" --label "DIFF (ORIGINAL MY)"
prompt = false
path = C:\Program Files (x86)\Meld\Meld.exe

可以使用Chocolatey从命令行安装Meld:

choco install meld

让我们定义一个shell函数来帮助我们比较TEXT EDITOR中[alias]下的两个sha-s(提交):

[alias]
showchangesbetween = "!w() { git difftool \"$1\" \"$2\" --dir-diff --ignore-all-space; }; w"

要在Meld(或其他你喜欢的diff工具)的帮助下比较提交,只需在命令行输入:

git showchangesbetween somesha123 somesha456

提交sha-s是很容易看到的输入

 git log 

为例。