这个答案对于查看签入git的两个文件之间的视觉差异非常有用: 我如何查看'git diff'输出与一个可视化的diff程序?

然而,我希望看到两个分支之间的视觉差异。到目前为止,我最好的选择似乎是:

git diff --name-status master dev

这不是很有信息量,也不是很直观。

还有更好的吗?


当前回答

尝试“difftool”(假设你有diff工具设置)-见https://www.kernel.org/pub/software/scm/git/docs/git-difftool.html

我发现名称状态良好的摘要,但difftool将迭代的变化(和-d选项给你的目录视图),例如。

$ git difftool their-branch my-branch

Viewing: 'file1.txt'
Launch 'bc3' [Y/n]:
...

或者像@rsilva4提到的-d和默认到你当前的分支,它只是-例如比较到master:

$  git difftool -d master..

...是的,有很多变体——https://www.kernel.org/pub/software/scm/git/docs/git-reset.html

其他回答

更新

麦克:我现在用SourceTree。彻底的建议。我特别喜欢你摆/摆帅哥的方式。

Linux:我成功地使用过:

smartgit GitKraken 注册

例如,在Ubuntu上安装smartgit:

从https://www.syntevo.com/smartgit/download/下载。deb 安装sudo DPKG -i /path/to/deb '


这是可行的:

git-diffall使用GUI diff工具,如meld。见第5点:

http://rubyglazed.com/post/15772234418/git-ify-your-command-line

这里有一篇关于git和meld的好文章:http://nathanhoad.net/how-to-meld-for-git-diffs-in-ubuntu-hardy

您也可以使用gitk轻松地做到这一点。

> gitk branch1 branch2

首先单击branch1的顶端。现在右键单击branch2的尖端,并选择Diff this->selected。

在GitExtensions中,你可以用Ctrl键在修订网格中选择两个分支。然后,您可以看到这些分支之间不同的文件。当你选择一个文件时,你会看到它的diff。

从这里开始

或者您可以右键单击任何修订,并选择比较>比较分支…

然后你可以选择与哪个分支进行比较:

最后,您会看到一个Diff窗口,列出两个分支之间不同的文件,对于每个文件,它都会显示一个Diff视图。

如果您正在使用Intellij Idea IDE,您可以只使用分支中的比较选项。

如果你正在使用github,你可以使用这个网站:

github.com/url/to/your/repo/compare/SHA_of_tip_of_one_branch...SHA_of_tip_of_another_branch

这将向你展示两者的比较。