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

相关推荐
kyriewen13 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
Dontla14 小时前
git bash打开Claude code报错:Claude Code on Windows requires git-bash.(别把git装其他位置,严格按照默认安装)找不到claude code
windows·git·bash
一个梦醒了14 小时前
安装git bash选项推荐
开发语言·git·bash
一只叫煤球的猫17 小时前
ThreadForge 源码解读二:一个 Task 从 submit 到完成,内部到底发生了什么?
java·后端·面试
呆萌的代Ma17 小时前
Git不强行推送,撤销最近几次的提交
git
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题 第110题】【并发篇】第10题:CAS 存在哪些问题?
java·开发语言·面试
秋919 小时前
Python工程师面试常问提问和回答(AI工程化方向 · 2026版)
人工智能·python·面试
西安邮电大学20 小时前
贪心算法详细讲解
java·后端·其他·算法·面试
透明的玻璃杯20 小时前
git应用
git
炸炸鱼.1 天前
Git+Jenkins实战(一):从零搭建自动化发布与回滚系统(附完整代码)
git·jenkins