当前位置: 首页 > news >正文

Git 合并冲突解决与状态分析笔记

前言

在使用 Git 进行代码管理时,合并分支是常见的操作之一。然而,在合并过程中可能会遇到冲突问题,尤其是在多人协作开发的场景下。本文将详细介绍如何解决 Git 合并冲突,并结合实际案例分析 git status 的输出含义。

背景

在一次项目开发中,我需要将远程的 master 分支合并到本地的 chenjj 分支上。在执行 git merge origin/master 时,遇到了文件冲突问题。以下是具体的操作步骤和解决方案。

问题描述

在执行以下命令时:git merge origin/master 这条命令的含义是将远程仓库 originmaster 分支的更改合并到当前分支中

git merge origin/master

终端输出了多个文件的冲突信息,包括普通文件(如 .js.vue.json)和二进制文件(如 .woff2.woff.ttf)。最终,git status 显示所有冲突已解决,但没有明确指出普通文件的冲突情况。

解决步骤

Git 合并代码的基本流程

1.切换到目标分支


使用 git checkout <target-branch> 切换到需要合并代码的目标分支。例如:

# 切换到目标分支(Chnejj)

git checkout Chnejj

2.执行合并操作


使用 git merge <source-branch> 将源分支的更改合并到目标分支。例如: 

# 合并 Chnejj 分支到 master分支

git master Chnejj

3.查看当前分支状态

运行以下命令查看当前分支的状态:

git status

 输出示例:

92391@DESKTOP-NSDKPQ6 MINGW64 ~/Desktop/app/likeban-applet2 (chenjj|MERGING)
$ git status
On branch chenjj
Your branch and 'origin/chenjj' have diverged,
and have 5 and 20 different commits each, respectively.
  (use "git pull" to merge the remote branch into yours)

You have unmerged paths.
  (fix conflicts and run "git commit")
  (use "git merge --abort" to abort the merge)

Changes to be committed:

        modified:   common/auth.js
        modified:   common/router.js
        modified:   common/scanAndQ.js
        new file:   components/news-components/news-ad.vue
        modified:   env_dev.js
        modified:   env_prod.js
        modified:   pages.json
        modified:   pages/app/index.vue
        modified:   pages/city/login/index.vue
        modified:   pages/city/login/login.vue
        modified:   pages/city/reveal/revealPage.vue
        modified:   pages/customerService/index.vue
        modified:   pages/governmentAffairs/hotwireFeedback/index.vue
        modified:   pages/gxbcyjs/jkzyjs/index.vue
        modified:   pages/gxbcyjs/yczyjs/index.vue
        modified:   pages/home/homeBusiness.vue
        modified:   pages/home/homePage.vue
        modified:   pages/home/subsistencePayment.vue
        modified:   pages/newsBusiness/index.vue
        modified:   pages/payment/heatingGs/history.vue
        new file:   pages/skipPage/Carousel.vue
        modified:   pages/skipPage/car.vue
        new file:   pages/skipPage/pay.vue
        modified:   pages/venueReservation/components/appointmentDetial.vue
        modified:   pages/venueReservation/components/bookingDetial.vue
        new file:   pages/venueReservation/components/notice.vue
        new file:   pages/venueReservation/feedback.vue
        modified:   pages/venueReservation/index.vue
        modified:   pages/venueReservation/my.vue
        modified:   pages/wuye/WuyeMain.vue
        modified:   pages/wuye/districtReport/districtReport.vue
        modified:   store/index.js

Unmerged paths:
  (use "git add <file>..." to mark resolution)

        both modified:   static/iconfont/iconfont.css
        both modified:   static/iconfont/iconfont.ttf
        both modified:   static/iconfont/iconfont.woff
        both modified:   static/iconfont/iconfont.woff2
  • 解释

    • 当前分支 chenjj 和远程分支 origin/chenjj 已经分叉。
    • 所有冲突已经解决,但合并尚未完成。
    • 列出了即将提交的更改文件。

4.开始关键性的解决冲突

  1. 解决二进制文件冲突

    • 保留本地版本:git checkout --ours -- <文件路径>
    • 保留远程版本:git checkout --theirs -- <文件路径>
#保留本地文件的指令 (我选择是保留本地的文件)

git checkout --ours -- static/iconfont/iconfont.woff2
git checkout --ours -- static/iconfont/iconfont.woff
git checkout --ours -- static/iconfont/iconfont.ttf
git checkout --ours -- static/iconfont/iconfont.css



# 保留远程的指令

git checkout --theirs -- static/iconfont/iconfont.woff2
git checkout --theirs -- static/iconfont/iconfont.woff
git checkout --theirs -- static/iconfont/iconfont.ttf
git checkout --theirs -- static/iconfont/iconfont.css


# 选择完成之后还需要对刚才保留下来的文件进行提交

git add static/iconfont/iconfont.woff2
git add static/iconfont/iconfont.woff
git add static/iconfont/iconfont.ttf
git add static/iconfont/iconfont.css

解决冲突的指令: 

提交保留下来的文件的指令: 

此时我们已经解决完成了冲突,但是我们还是再写入查看当前分支状态的指令,再次确定一下所有的冲突都解决完成了

$ git status

 

此时输入指令之后,提示信息中没有冲突的提示了,这就证明了我们已经解决了所有的冲突

5. 理解为什么没有显示普通文件的冲突

  • 冲突已经解决

    • 在之前的合并过程中,Git 提示了一些普通文件存在内容冲突(如 common/auth.jspages.json 等)。
    • 我手动编辑了这些文件,删除了冲突标记(<<<<<<< HEAD=======>>>>>>> origin/master),并保留了需要的内容。
    • 使用 git add <文件路径> 标记这些文件为已解决。
  • 当前状态是“所有冲突已解决”

    • git status 显示 All conflicts fixed but you are still merging.,说明冲突已经解决。
    • 普通文件现在属于“Changes to be committed”,不会再显示为冲突文件。
  •  验证是否还有未解决的冲突

    为了确保没有遗漏的冲突,可以运行以下命令:

  • 检查是否有未解决的冲突文件

git diff --name-only --diff-filter=U

执行的 git diff --name-only --diff-filter=U 命令用于列出所有未解决的合并冲突文件。--name-only 参数表示只显示文件名,不显示具体的差异内容,而 --diff-filter=U 参数表示只显示那些存在未解决冲突(Unmerged)的文件。

该命令的输出结果是空的、没有输出任何文件名,这意味着在执行该命令时,已经没有未解决的冲突文件了,或者您可能需要先运行 git add 命令将解决冲突后的文件标记为已解决。

6. 完成合并

在确认所有冲突都已经解决后,运行以下命令完成合并

$ git commit -m "解决合并冲突"

7. 推送更改到远程

完成合并后,将本地分支推送到远程:

$ git push origin chenjj:chenjj

如果远程分支已经有新的提交记录,而你的本地分支没有包含这些记录,Git 可能会拒绝推送。此时需要先拉取远程分支的更改并解决冲突:

git pull origin chenjj

相关文章:

  • 发现问题 python3.6.13+django3.2.5 只能以asgi启动server 如何解决当前问题
  • rust笔记1-学习资料推荐
  • C#设计模式 学习笔记
  • OpenProject项目管理系统
  • 如何在Windows 10操作系统中安装并配置PHP集成软件XAMPP
  • 微前端qiankun打包部署
  • js 跳出循环
  • Moonshot AI 新突破:MoBA 为大语言模型长文本处理提效论文速读
  • java项目引用sevenzipjbinding依赖报错问题
  • Linux基础开发工具的使用(apt、vim、gcc、g++、gdb、make、makefile)
  • 代码审计入门学习之sql注入
  • 持续记录FASTAI学习踩坑
  • 单片机 Bootloade与二进制文件的生成
  • 什么是电力交易员
  • 基于ffmpeg+openGL ES实现的视频编辑工具-添加滤镜(七)
  • Ecode在流程表单中插入自定义内容
  • 从CNN到Transformer:遥感影像目标检测的未来趋势
  • 语音控制热水器WTK69000离线语音识别芯片方案:迈向智能家居新时代
  • 一款社交媒体中查用户名的工具
  • 【Python】如何在 Linux/Windows 系统中设置 PYTHONPATH 环境变量
  • 德国总理默茨发表首份政府声明:将提升国防能力,全力发展经济
  • 美国调整对华加征关税
  • 佩斯科夫:俄方代表团15日将在伊斯坦布尔等候乌克兰代表团
  • 京东一季度净利增长五成,营收增速创近三年新高,称外卖业务取得显著进展
  • 成都警方通报:8岁男孩落水父母下水施救,父亲遇难
  • 香港根据《维护国家安全条例》订立附属法例