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

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

git diff --name-status master dev

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

还有更好的吗?


当前回答

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

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

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

其他回答

使用带范围的git diff。

git diff branch1..branch2

这将比较每个分支的尖端。

如果你真的想要一些GUI软件,你可以尝试一些像SourceTree这样支持Mac OS X和Windows的软件。

下面是如何在visual Studio中看到整个提交与单个文件之间的视觉差异(在VS 2017中测试)。不幸的是,它只适用于一个分支中的提交:在“团队资源管理器”中,选择“分支”视图,右键单击回购,并选择“查看历史”,如下图所示。

然后,当前分支的历史记录出现在主区域中。(之前在当前分支上提交的分支被标记为标签。)现在用Ctrl-Left选择几个提交,然后右键单击并从弹出菜单中选择“Compare commit…”。

有关在Microsoft世界中比较分支的更多信息,请参阅这个stackoverflow问题:使用Visual Studio的git分支之间的差异。

更新

麦克:我现在用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

如果你使用的是OSX或Windows 7+, Atlassian SourceTree可以很好地解决这个问题。它是免费的。

您可以在并排的diff设置中看到分阶段的更改,并且可以轻松地将本地分支与远程分支和任何其他两个分支进行比较。当选择多个文件时,差异显示如下:

假设你已经签出了一个功能分支,你想要查看与'master'的差异,右键单击'master'分支并选择“diff against current”。

不幸的是,它似乎不会很快出现在*nix发行版中。

为了看到两个分支之间所有差异的可视化差异,我喜欢合并两个分支-不提交合并-然后使用git gui或git Extensions来获得差异的概述。

Git命令行用于合并而不提交:

git checkout branchA
git merge --no-commit --no-ff branchB

完成后,可以撤消与的合并

git merge --abort

(h/t @jcugat’s的评论)