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

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

git diff --name-status master dev

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

还有更好的吗?


当前回答

你也可以使用vscode来比较使用CodeLense扩展的分支,这已经在这个SO中回答了:如何在Visual studio代码中比较不同的分支

其他回答

如果你使用优秀的WebStorm编辑器,你可以与任何你想要的分支进行比较:

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

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

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

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

git merge --abort

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

更新

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

你也可以使用Perforce中的免费P4Merge来做到这一点:

http://www.perforce.com/product/components/perforce-visual-merge-and-diff-tools

关于将其与Git集成的详细信息可以在这里和这里找到

但从以上链接中快速总结如下:

在~/中放入以下位。然后你可以用$ git mergetool和$ git difftool来使用p4merge 注意$ git diff仍然会使用默认的内联diff查看器:)(git版本1.8.2测试)

.gitconfig的更改

[merge]
  keepBackup = false
    tool = p4merge
[mergetool "p4merge"]
    cmd = /Applications/p4merge.app/Contents/Resources/launchp4merge "\"$PWD/$BASE\"" "\"$PWD/$REMOTE\"" "\"$PWD/$LOCAL\"" "\"$PWD/$MERGED\""
    keepTemporaries = false
    trustExitCode = false
    keepBackup = false
[diff]
    tool = p4merge
[difftool "p4merge"]
    cmd = /Applications/p4merge.app/Contents/Resources/launchp4merge "\"$REMOTE\"" "\"$LOCAL\""

尝试“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