git merge :开发分支与主分支的交互

一、开发分支(dev)上的代码达到上线的标准后,要合并到 master 分支

复制代码
git checkout dev
git pull
git checkout master
git merge dev
git push -u origin master

二、当master代码改动了,需要更新开发分支(dev)上的代码

复制代码
git checkout master 
git pull 
git checkout dev
git merge master 
git push -u origin dev
一、详细说明:开发分支(dev)上的代码达到上线标准后,合并到主分支
  1. 切换到开发分支并拉取最新代码

    复制代码
    git checkout dev
    git pull
  2. 切换到主分支

    复制代码
    git checkout master
  3. 合并开发分支到主分支

    复制代码
    git merge dev
  4. 解决冲突(如果有)

    • 如果合并过程中出现冲突,Git 会提示哪些文件有冲突。

    • 打开这些文件,手动解决冲突。

    • 解决冲突后,添加已解决的文件:

      复制代码
      git add <conflicted-file>
  5. 完成合并并推送更改

    复制代码
    git commit -m "Merge dev into master"
    git push -u origin master
二、详细说明:当主分支代码改动后,需要更新开发分支上的代码
  1. 切换到主分支并拉取最新代码

    复制代码
    git checkout master
    git pull
  2. 切换到开发分支

    复制代码
    git checkout dev
  3. 合并主分支到开发分支

    复制代码
    git merge master
  4. 解决冲突(如果有)

    • 如果合并过程中出现冲突,Git 会提示哪些文件有冲突。

    • 打开这些文件,手动解决冲突。

    • 解决冲突后,添加已解决的文件:

      复制代码
      git add <conflicted-file>
  5. 完成合并并推送更改

    复制代码
    git commit -m "Merge master into dev"
    git push -u origin dev
补充:遇到冲突后的处理情况

当合并过程中出现冲突时,Git 会在冲突文件中插入冲突标记,帮助你识别和解决冲突。冲突文件中的冲突标记如下所示:

复制代码
<<<<<<< HEAD
// 当前分支的代码
=======
// 要合并分支的代码
>>>>>>> <branch-name>

以下是一个详细的处理冲突的步骤:

  1. 识别冲突文件

    • Git 会在合并过程中提示哪些文件有冲突。例如:

      复制代码
      Auto-merging file.txt
      CONFLICT (content): Merge conflict in file.txt
  2. 打开冲突文件

    • 使用文本编辑器打开冲突文件,找到冲突标记。
  3. 手动解决冲突

    • 删除冲突标记,并根据实际情况选择保留或合并代码。例如:

      复制代码
      // 假设这是冲突文件的内容
      <<<<<<< HEAD
      public void methodA() {
          System.out.println("Method A");
      }
      =======
      public void methodA() {
          System.out.println("Updated Method A");
      }
      >>>>>>> dev

      解决后的代码:

      复制代码
      public void methodA() {
          System.out.println("Updated Method A");
      }
  4. 添加已解决的文件

    • 使用 git add 命令添加已解决的文件:

      复制代码
      git add file.txt
  5. 完成合并

    • 使用 git commit 命令完成合并:

      复制代码
      git commit -m "Resolve merge conflicts"
  6. 推送更改

    • 使用 git push 命令将更改推送到远程仓库:

      复制代码
      git push -u origin <branch-name>
相关推荐
字节源流3 小时前
关于maven的依赖下不下来的问题
java·maven
pjx9873 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
prinrf('千寻)4 小时前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
老华带你飞4 小时前
实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)
java·数据库·spring boot·小程序·论文·毕设·实习记录小程序
在未来等你4 小时前
互联网大厂Java求职面试:AI与大模型应用集成及云原生挑战
java·微服务·ai·kubernetes·大模型·embedding·spring ai
源码技术栈5 小时前
SaaS基于云计算、大数据的Java云HIS平台信息化系统源码
java·大数据·云计算·云his·his系统·云医院·区域his
编程、小哥哥5 小时前
互联网大厂Java面试:从Spring Boot到微服务架构的技术深挖
java·spring boot·redis·微服务·prometheus·面试技巧
揽你·入怀5 小时前
数据结构:ArrayList简单实现与常见操作实例详解
java·开发语言
okok__TXF5 小时前
SpringBoot3+AI
java·人工智能·spring
AA-代码批发V哥5 小时前
Math工具类全面指南
java·开发语言·数学建模