我想合并两个分开了一段时间的分支,并想知道哪些文件被修改了。

穿过此链接:http://linux.yyz.us/git-howto.html(移动到web.archive.org),这非常有用。

我遇到的比较分支的工具有:

git diff主机。。树枝git日志主机。。树枝git短日志主机。。树枝

我想知道是否有类似于“gitstatus master…branch”的东西来只查看两个分支之间不同的文件。

在不创建新工具的情况下,我认为这是您现在最接近的方法(如果文件被多次修改,这当然会显示重复):

git diff主机。。分支|grep“^diff”

我想知道我是否错过了什么。。。


当前回答

还有一种基于GUI的方法。

你可以使用gitk。

运行:$gitk--全部右键单击分支的提交,然后在弹出菜单中选择标记此提交。右键单击另一个分支的提交,然后选择Diff this->标记的提交或Diff标记的提交->此。

然后,右下面板中会有一个已更改的文件列表,左下面板中有差异详细信息。

其他回答

有两个分支

A(您正在工作的分支机构)B(要与之比较的另一个分支)

在分支A中,您可以键入

git diff --color B

那么这将为您提供

重要的一点是

分支A中有绿色文本分支B中存在红色文本

注意,如果您不喜欢结果,git可以很容易地尝试合并并避免任何问题。这可能比提前寻找潜在问题更容易。

还有一种基于GUI的方法。

你可以使用gitk。

运行:$gitk--全部右键单击分支的提交,然后在弹出菜单中选择标记此提交。右键单击另一个分支的提交,然后选择Diff this->标记的提交或Diff标记的提交->此。

然后,右下面板中会有一个已更改的文件列表,左下面板中有差异详细信息。

也可以使用视觉差异。

例如,如果您正在使用Sourcetree,您可以在日志视图中选择任意两个提交。

(在大多数情况下,我个人更喜欢使用GUI来实现这一点,我将向那些可能不熟悉GUI选项的人发布这一点。)

git diff revision_n revision_m

如果revision_n和revision_m是连续提交,则输出与git显示修订版-m