如何解决代码冲突

如果你在执行 git pull --rebase origin dev 时出现了代码冲突,这种情况一般是dev远程分支与你本地的分支出现了差异。废话不多说,以下是解决步骤:

1. 查看冲突文件

首先,打开冲突文件,你会看到类似这样的标记:

plaintext 复制代码
<<<<<<< HEAD
// 远程分支的代码(origin/dev)
=======
// 你本地提交的代码(5ac06d7)
>>>>>>> 5ac06d7... fix:同步XXX修改;

2. 手动解决冲突

编辑该文件,保留你需要的内容,并删除冲突标记(<<<<<<<=======>>>>>>>)。例如:

vue 复制代码
// 合并后的正确代码
<div>合并后的内容</div>

一般它会提示你用你本地的版本还是用远程线上的版本,这个过程全靠你自己来判断了,如果拿不定主意的,你可能得找到线上提交这部分修改的人,跟他确认清楚再做取舍。

3. 标记冲突已解决

解决冲突后,执行:

bash 复制代码
git add src/views/***/index.vue

将代码提交暂存。

4. 继续 rebase

bash 复制代码
git rebase --continue

这条命令可以把刚才因为冲突停止的变基操作继续下去。

5. 如果遇到更多冲突

重复步骤 1-4,直到所有冲突解决完毕。

6. 完成 rebase

所有冲突解决后,rebase 会自动完成,你的提交会被应用到更新后的分支上。

7. 推送代码

最后,强制推送到远程分支,因为 rebase 修改了历史,普通的push已经无效了,git会认为你的本地分支dev-x和远程的dev分支已经不同了,所以要执行强制推送:

bash 复制代码
git push --force-with-lease origin dev-x

不过,这个前提是你确认代码冲突已经解决,你现在是最新的提交。

注意事项:

  • 如果中途想放弃 rebase,可以执行:

    bash 复制代码
    git rebase --abort
  • 确保强制推送前没有其他人正在协作该分支,以免覆盖他人的提交。

总结步骤:

bash 复制代码
# 1. 手动解决冲突后添加文件
git add <冲突文件>

# 2. 继续 rebase
git rebase --continue

# 3. 强制推送
git push --force-with-lease origin dev-x

这样就能安全地同步远程更改并保留你的提交。

相关推荐
Aliex_git5 天前
Dockerfile 优化实践笔记
笔记·学习·gitlab
成为你的宁宁6 天前
Jenkins 自动化部署前后端分离若依项目全攻略:涵盖环境配置、Maven/Node.js 工具安装、GitLab 项目协同,及前后端构建、服务器推送与代码更新验证全步骤
node.js·自动化·gitlab·jenkins·maven
sunshinebo6 天前
一次 GitLab 无法启动的排查:Docker 日志把 500G 磁盘打满
docker·eureka·gitlab
何以不说话6 天前
DevOps、Git 和 GitLab
git·gitlab·devops
ZAEQgyKFs9 天前
永磁同步电机模型预测电流控制+滑模控制 [1]速度环采用滑模控制 滑模控制器采用新型趋近律与扰...
gitlab
马克Markorg9 天前
使用 Docker Compose 本地部署 GitLab 教程
docker·容器·gitlab
大尚来也12 天前
CI/CD 流水线搭建实战:GitHub Actions vs GitLab CI 2026 深度对比与选型指南
ci/cd·gitlab·github
ProgramHan13 天前
github、gitlab、gitee分别都是什么,为什么不能访问?
gitee·gitlab·github
Aliex_git15 天前
Gitlab Runner 配置实践
笔记·学习·ci/cd·gitlab
阿莫西林夹馍15 天前
GitLab的IP地址发生变更导致Runner掉线
gitlab