【软件工程】如何使用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 上的重新应用)

相关推荐
蒸汽求职5 小时前
跨越 CRUD 内卷:半导体产业链与算力基建下的软件工程新生态
人工智能·科技·面试·职场和发展·软件工程·制造
小兵张健5 小时前
一场大概率没拿到 offer 的面试,让我更坚定去做喜欢的事
人工智能·面试·程序员
SiYuanFeng8 小时前
新手学Git:如何把本地 Git 项目上传到 GitHub
git·github
AI人工智能+电脑小能手8 小时前
【大白话说Java面试题】【Java基础篇】第7题:HashMap的get流程是什么
java·后端·面试·哈希算法·散列表·hash-index·hash
前端若水9 小时前
git回退并合并分支操作
git
豹哥学前端10 小时前
别再背“var 提升,let/const 不提升”了:揭开暂时性死区的真实面目
前端·面试
何陋轩10 小时前
【重磅】悟空来了:国产AI编程助手深度测评,能否吊打Copilot?
人工智能·算法·面试
小研说技术12 小时前
实时通信对比,一场MCP协议的技术革命
前端·后端·面试
山栀shanzhi12 小时前
C/C++之:构造函数为什么不能设置为虚函数?
开发语言·c++·面试
我叫黑大帅14 小时前
受保护的海报图片读取方案 - 在不公开静态资源目录下如何获取静态资源
后端·python·面试