news 2026/5/21 10:57:12

GIT使用小白(进阶二:冲突解决)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GIT使用小白(进阶二:冲突解决)

Git 冲突处理策略(最佳实践)

冲突不可怕,关键是:定位冲突 → 分析冲突 → 解决冲突 → 测试 → 提交
只要按下面的步骤走,一次就能干干净净解决。


🔥一、常见冲突出现的场景

  1. git pull / git pull --rebase 时
  2. git rebase某个分支时(最常见)
  3. git merge某个分支时
  4. 多人改了同一个文件的同一段代码

🧭二、遇到冲突时的通用流程


步骤 1:知道哪里冲突了

Git 会告诉你哪些文件冲突:

gitstatus

通常会看到:

both modified: src/foo/bar.cpp

步骤 2:打开冲突文件,看到冲突标记

冲突段长这样:

<<<<<<< HEAD 这是你本地修改的版本 ======= 这是远程(或你 rebase 到的分支)版本 >>>>>>> origin/main

解释:

  • HEAD 区块= 当前分支里的内容
  • 下面区块= 你要 merge 或 rebase 的分支内容

步骤 3:手动选择要保留的内容

你有三种选择:

✔ 方案 1:保留我的(本地)版本

删掉远程区块:

我的代码

✔ 方案 2:保留远程版本(目标分支,如 yellow)

目标分支的代码

✔ 方案 3:合并两个版本(最常见)

手动编辑成你想要的最终样子,例如:

融合后正确的代码

步骤 4:标记冲突解决

编辑完后:

gitadd<冲突文件>

步骤 5:继续操作

如果你在用rebase

gitrebase --continue

如果你在用merge

gitcommit

(如果 Git 自动生成 merge commit message,也可以直接用)


步骤 6:如果你反悔想取消

停止 rebase

gitrebase --abort

停止 merge

gitmerge --abort

🧪三、冲突后必须做的检查

解决冲突后一定要:

  1. 重新编译 / 运行单元测试
  2. 确认逻辑正确
  3. 确认没有漏掉某些人的代码

这一步很重要,因为冲突解决错误比冲突本身更可怕。


🧰四、常见冲突处理技巧(进阶)


⭐ 技巧 1:可视化工具更简单

gitmergetool

可调用:

  • VSCode
  • Meld
  • KDiff3
  • Beyond Compare

VSCode 用户可以直接:

code.

然后在文件中点“Accept Incoming / Accept Current / Both”。


⭐ 技巧 2:你想要全保留 remote(例如 yellow 分支)

这是“保留对方版本”的快捷法:

gitcheckout --theirs.gitadd.gitrebase --continue

或 merge 场景:

gitcheckout --theirs.gitadd.gitcommit

⭐ 技巧 3:你想要全部保留自己的

gitcheckout --ours.gitadd.gitrebase --continue

⭐ 技巧 4:查看冲突发生在谁的提交

gitlog --merge

⭐ 技巧 5:修冲突之后检查差异

gitdiff--cached

确保你 add 后的内容真的正确。


🛡️五、如何减少未来冲突?(最佳实践)

  1. 每次开发前先同步 yellow
gitcheckout yellowgitpullgitcheckout my-featuregitrebase yellow
  1. 提交保持小而清晰
  2. 功能模块化修改,避免多人改同一文件
  3. 经常 push,减少你的变更积累
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/16 22:40:15

震惊!正规外卖小程序竟藏这5大猫腻,商家千万注意!

震惊&#xff01;正规外卖小程序竟藏这5大猫腻&#xff0c;商家千万注意&#xff01; 在数字化餐饮时代&#xff0c;外卖小程序已成为商家拓展业务的重要渠道。然而&#xff0c;看似正规的外卖平台背后&#xff0c;往往暗藏着诸多不为人知的风险。作为餐饮从业者&#xff0c;了…

作者头像 李华
网站建设 2026/5/19 16:13:41

零基础入门:你的第一个VSCode插件开发指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个最简单的VSCode插件教学项目&#xff0c;功能是在状态栏显示当前时间。要求包含&#xff1a;1) 完整的环境配置说明 2) 分步骤代码讲解 3) 调试方法 4) 打包发布指南。使用…

作者头像 李华
网站建设 2026/5/19 6:07:23

Flipper Zero玩转Amiibo:2025年最酷的游戏解锁指南

还在为心爱的Amiibo玩具价格发愁&#xff1f;想要一键解锁《塞尔达传说》、《超级马里奥》中的隐藏内容&#xff1f;今天我们就来聊聊如何用Flipper Zero这个神奇的小设备&#xff0c;实现Amiibo的完美模拟&#xff01; 【免费下载链接】Flipper Playground (and dump) of stuf…

作者头像 李华
网站建设 2026/5/21 6:59:02

Ncorr免费2D数字图像相关软件完整使用教程

Ncorr免费2D数字图像相关软件完整使用教程 【免费下载链接】ncorr_2D_matlab 2D Digital Image Correlation Matlab Software 项目地址: https://gitcode.com/gh_mirrors/nc/ncorr_2D_matlab Ncorr是一款基于MATLAB的开源2D数字图像相关软件&#xff0c;专门用于精确测量…

作者头像 李华
网站建设 2026/5/19 15:57:41

Onekey深度解析:Steam游戏清单下载完整教程

Onekey深度解析&#xff1a;Steam游戏清单下载完整教程 【免费下载链接】Onekey Onekey Steam Depot Manifest Downloader 项目地址: https://gitcode.com/gh_mirrors/one/Onekey 想要轻松获取Steam游戏清单却苦于复杂的操作流程&#xff1f;Onekey这款开源工具将彻底改…

作者头像 李华
网站建设 2026/5/19 12:40:02

前端新手必看:简单搞定循环引用JSON问题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个交互式学习页面&#xff0c;包含&#xff1a;1) 循环引用的动画图解 2) 可操作的简单示例(朋友互相引用) 3) 实时错误演示(尝试JSON.stringify报错) 4) 三种基础解决方案(删…

作者头像 李华