解决 Git 冲突

2026-01-07 23:23:29

解决 Git 冲突当您在团队中工作时,可能会遇到有人将更改推送到您当前正在处理的文件的情况。 如果这些更改不重叠(即,对不同代码行进行了更改),则冲突文件将自动合并。 但是,如果相同的行受到影响,Git 无法随机选择一方,而是要求您解决冲突。

在 Git 中,当您尝试执行以下操作之一时,可能会出现冲突: pull、 merge、 rebase、 cherry-pick、 unstash changes 或 apply a patch。 如果存在冲突,这些操作将会失败,系统会提示您接受上游版本、偏向您的版本或合并更改:

Git 级别检测到冲突时,会自动触发 冲突 对话框。

如果您在此对话框中点击 关闭 或从命令行调用导致合并冲突的 Git 操作, 合并冲突 节点将出现在 更改 视图中的 提交 工具窗口,并带有解决这些冲突的链接:

IntelliJ IDEA 提供了一个用于本地解决冲突的工具。 此工具由三个窗格组成:

左侧窗格显示只读本地副本

右侧窗格显示了已签入存储库的只读版本。

中央窗格是一个功能齐全的编辑器,用于显示解决冲突的结果。 最初,此窗格的内容与文件的 基准修订版本相同,也就是两个冲突版本来源于该修订版本。

修改的行

已删除的行

新增行

冲突行

解决冲突在 冲突 对话框中点击 合并 ,在 本地更改 视图中的 解决 链接,或者在编辑器中选择冲突文件,并从主菜单中选择 VCS | Git | 解决冲突。

要自动合并所有不冲突的更改,请点击工具栏上的 (应用所有无冲突的更改)。 您还可以使用 (从左侧应用无冲突的更改 )和 (从右侧应用无冲突的更改 )分别从对话框的左/右部分合并无冲突的更改。

要解决冲突,您需要选择应用哪个操作(接受 或忽略 )到左侧(本地)和右侧(仓库)版本,并在中央窗格中检查结果代码:

您还可以右键点击中央窗格中高亮显示的冲突,并使用上下文菜单中的命令。 使用左侧解决 和 使用右侧解决 命令分别提供了接受一侧更改和忽略另一侧更改的快捷方式:

对于简单冲突(例如,如果在不同文件修订版中修改了同一行的开头和结尾),允许一键合并更改的 解决简单冲突 按钮将变得可用。

此类冲突不会通过 应用所有无冲突的更改 操作解决,您必须确保它们得到妥善解决。

请注意,中间窗格是一个全功能编辑器,因此您可以直接在此对话框中更改生成的代码。

在解决冲突时,比较不同版本可能也是有用的。 使用 工具栏按钮调用选项列表。 请注意, 基准 指的是本地版本和存储库版本源自的文件版本(最初显示在中间窗格中),而 中间 指的是最终版本。

在中央窗格中查看合并结果,然后点击 应用。

效率提示自动应用无冲突的更改您可以配置 IntelliJ IDEA 始终自动应用不冲突的更改,而无需从 合并 对话框中指示它去执行。 为此,请在 工具 | Diff Merge 设置页面  Ctrl+Alt+S 上选择 自动应用无冲突的更改 选项。

在中央窗格中管理更改您可以使用工具栏在中央窗格中管理更改,该工具栏会在您悬停在装订区域的更改标记上并点击它时出现。 工具栏与显示被修改行先前内容的框架一起显示:

例如,当有多个不冲突的更改,且您只需要跳过其中一两个时,使用此工具栏中的 应用所有不冲突的更改 操作同时应用所有更改,然后使用 还原 操作撤销不需要的更改会更容易。

处理与 LF 和 CRLF 行结尾相关的冲突团队中经常有人使用不同的操作系统,对同一个存储库进行贡献。 这可能会导致行尾问题,因为 Unix、Linux 和 macOS 使用 LF ,而 Windows 使用 CRLF 来标记行尾。

IntelliJ IDEA 显示 差异查看器 中的换行符差异,因此您可以手动修复它们。 如果您希望 Git 自动解决此类冲突,您需要在 Windows 上设置 core.autocrlf 属性为 true ,在 Linux 和 macOS 上设置为 input (详情请参阅 处理行结尾)。 您可以在 Windows 上运行 git config --global core.autocrlf true 或在 Linux 和 macOS 上运行 git config --global core.autocrlf input 手动更改配置。

然而,IntelliJ IDEA 可以自动分析您的配置,在您即将提交 CRLF 到远程存储库时发出警告,并建议根据您的操作系统将 core.autocrlf 设置为 true 或 input。

为启用 LF 和 CRLF 行分隔符的智能处理,请打开 设置 对话框 Ctrl+Alt+S ,并选择左侧的 版本控制 | Git 节点。 启用 当即将提交 CRLF 行分隔符时发出警告 选项。

您启用此选项后,IntelliJ IDEA 将在每次提交带有 行分隔符警告对话框 分隔符的文件时显示 CRLF ,除非您在受影响的文件中设置了任何相关的 Git attributes (在这种情况下,IntelliJ IDEA 认为您清楚了解自己在做什么并从分析中排除此文件)。

在 行分隔符警告对话框 中,点击以下其中一个:

按原样提交 忽略警告并提交带有 CRLF 分隔符的文件。

修复并提交 需要根据您的操作系统,将 core.autocrlf 属性设置为 true 或 input。 因此,在提交之前, CRLF 行分隔符将被替换为 LF。

如果稍后您需要查看在合并过程中如何解决冲突,您可以在 Git 工具窗口的 日志 选项卡中找到所需的合并提交 Alt+9 ,在右侧的 提交详细信息 窗格中选择一个包含冲突的文件,然后点击 或按 Ctrl+D。 如需了解更多信息,请参阅 查看更改如何合并。

观看此视频以了解更多有关如何解决合并冲突的信息:

最后修改日期: 2025年 12月 2日调查 Git 仓库中的更改将更改分组到changelist中

    为什么我的JJ那么小?都是因为小时候没干这事!
    孩童游戏哪些好玩 十大必玩孩童游戏精选

    Copyright © 2022 摩洛哥世界杯_直播世界杯决赛 - dgaida.com All Rights Reserved.