为什么拉代码时总会多出一个提交?

前言

在pull代码时,有时候会产生一个额外的提交记录,并且需要commmit。对于我这种有轻微代码洁癖的人看起来有点不爽。经过学习后发现原来这和git的merge时的策略有关,下面简单介绍这两种方式。

Fast Forward

在两个分支没有分叉时,会执行快速前进(Fast Forward)合并,即直接将当前分支的指针指向即将合并的分支。这种方式不会产生新节点。

例如下面的图片,在feat1上提交了2个commit,此时在main上执行

shell 复制代码
git merge feat1

结果是main和feat1指向同一个节点

3-way

如果两个分支有分叉,例如下面的情况:

此时在main上执行merge后会进行3-way merge,下面详细介绍3-way merge

3-way代表需要操作3个节点,即:

  1. main的当前指针,即C3
  2. feat1当前的指针,即C2
  3. 这两个分支的最近公共祖先(common ancestor), 即C1

开始时首先会生成一个新节点C4,此节点有两个parent commit, 即C2和C3。 然后对C1和C2进行diff, 以及对C1和C3进行diff。如果某个位置只有一方进行更改,则保留。如果两方都进行了修改,则标记为冲突,需要手动解决。解决完冲突后,会进行commit生成节点C4。中途如果想放弃合并可以使用git merge --abort


结论

原来采用3-way策略的时候就会产生额外的提交记录,这种方式记录了git操作的痕迹。如果希望提交记录整洁一些应该如何做呢?那就是使用git rebase操作!我将会近期将会更新下一篇中详细讲解!

相关推荐
CoderJia程序员甲2 小时前
GitHub 热榜项目 - 日榜(2025-12-15)
git·ai·开源·llm·github
大柏怎么被偷了2 小时前
【Git】远程操作
git
studytosky3 小时前
Linux 基础开发工具(3):Git 控制与 GDB 调试实用指南
linux·运维·服务器·网络·数据库·git
云闲不收4 小时前
AI编程系列——git-worktree并行开发
git·ai编程
秦时明月天明4 小时前
GitLab SSH Key 过期:git pull failed : remote your ssh key has expired
git·ssh·gitlab
桃花岛主705 小时前
命令提交git到github上的步骤
git·github
AI逐月5 小时前
Git 停止追踪已提交文件问题
大数据·git·elasticsearch
是毛毛吧5 小时前
开发环境配置指南:解决 GitHub 连接超时与依赖下载失败的问题
网络·git·网络安全·docker·信息与通信
bj_zhb6 小时前
git stash 用法
git
rockmelodies6 小时前
本地 PyCharm 生成的 Git 仓库与 GitHub 远程仓库关联起来
git·pycharm·github