【软件工程】如何使用Git Rebase同步团队开发进度

问题背景

现在,我正在我本地的私人开发分支feat/wu-sunflower/do_some_thing(对应云端分支origin/feat/wu-sunflower/do_some_thing),进行开发。

同时我的同事对代码也进行了一些改动(并且已经merge进了团队云端分支origin/dev)。我应该如何通过git rebase,与我的同事同步开发进度?

步骤

步骤 1:确保工作目录干净

检查工作目录中是否有未commit的修改。

bash 复制代码
git switch feat/wu-sunflower/do_some_thing  # 切换到我的分支
git status

如果有,请先commit,或者执行git stash把这些变动临时藏匿起来。

bash 复制代码
# 1. 正在开发中,修改了文件 A 和 B(未提交)
git status  # 显示有修改
# 2. 需要拉取团队最新代码
git stash -m "开发到一半的功能 A"
# 3. 现在工作目录干净了,可以拉取代码
git pull origin dev
# 4. 恢复之前的修改
git stash pop  # 或 git stash apply
# 5. 如果有冲突,手动解决后继续开发

步骤 2:拉取团队最新代码(不自动合并)

bash 复制代码
git fetch origin dev # 获取云端 dev 分支的最新提交

步骤 3:变基(rebase)我的分支到最新 dev

bash 复制代码
git rebase origin/dev  # 将当前分支变基到 origin/dev

此时可能出现冲突(因我的修改和同事的修改冲突)。

步骤 4:解决冲突(如果有)

定位冲突文件:

bash 复制代码
git status  # 查看冲突文件列表

然后手动编辑文件,解决冲突(文件中的 <<<<<<<>>>>>>> 标记区域)。

之后手工告知git,冲突已解决:

bash 复制代码
git add <冲突文件路径>  # 将解决后的文件加入暂存区

继续变基:

bash 复制代码
git rebase --continue

重复此过程直到所有冲突解决。

若需放弃变基:

bash 复制代码
git rebase --abort  # 回到 rebase 前的状态

步骤 5:推送更新到我的云端分支

shell 复制代码
git push origin feat/wu-sunflower/do_some_thing --force-with-lease

此操作将把变基后的本地仓库推送到云端分支origin/feat/wu-sunflower/do_some_thing

最终效果

css 复制代码
我的原始提交:          A--B--C [feat/wu-sunflower/...]
团队 dev 更新:         D--E--F [origin/dev]
变基后:                D--E--F--A'--B'--C' [feat/wu-sunflower/...]

A', B', C' 是我的提交在最新 dev 上的重新应用)

相关推荐
kyriewen1 天前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
罗超驿1 天前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
做人求其滴1 天前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
小江的记录本1 天前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
ricardo19731 天前
# Tree Shaking 深度解析:为什么你的代码没被摇掉?
前端·面试
小江的记录本1 天前
【Java基础】反射与注解:核心原理、自定义注解、注解解析方式(附《思维导图》+《面试高频考点清单》)
java·数据结构·python·mysql·spring·面试·maven
罗超驿1 天前
19.告别复杂SQL!用MySQL视图把逻辑拆成“变量”式操作
数据库·mysql·面试
我叫张小白。1 天前
Git 分支管理与团队协作
git
DogDaoDao1 天前
Windows 下 Git 报错:`touch` 无法识别 —— 原因分析与 7 种解决方案(从入门到精通)
windows·git·程序员·npm·powershell·cmd·touch
jiayong231 天前
前端面试题库 - 浏览器与网络篇
前端·网络·面试