Learn Git Branching:提交的技巧

这道题,是 Learn Git Branching 的练习题,叫"提交的技巧 #1"。

题目分析

当前状态(左侧图):

  • C0 ← C1 ← C2 ← C3
  • main 指向 C1
  • newImage 指向 C2
  • caption*(当前分支)指向 C3

目标状态(右侧图):

  • maincaption 最终指向同一个提交
  • newImageC1 之后(单独一条线)
  • 整体结构是对 newImage 的提交做了修改后,caption 的内容被重新应用上去

题目意图

你需要修改 newImage(C2)这个提交,但 caption(C3)依赖它。直接修改 C2 很麻烦,所以正确思路是:

git rebase -i 调整顺序 → 修改 → 再 rebase 回来

解题步骤

bash 复制代码
# 1. 把 caption 分支上的提交顺序对调(把 newImage 的提交放到最上面)
git rebase -i HEAD~2
# 在交互界面中,把 newImage 对应的提交移到 caption 提交的上方

# 2. 现在 newImage 在最顶,对它进行修改
git commit --amend

# 3. 再次用 rebase -i 把顺序换回来(caption 在上,newImage 在下)
git rebase -i HEAD~2

# 4. 把 main 和 newImage 分支指向对应提交
git branch -f main HEAD
git branch -f newImage HEAD~1

# 5. 重置到正确位置
git rebase caption main

核心思路总结

步骤 操作 目的
rebase -i HEAD~2 换序 把要改的提交移到顶部
commit --amend 修改该提交内容
rebase -i HEAD~2 换回 恢复原来顺序
移动分支指针 让 main/newImage 指向正确位置

这道题的核心考点就是:当你想修改历史中间某个提交时,先用 rebase -i 把它"浮"到顶部,改完再换回来

相关推荐
周小码3 小时前
10分钟搭建私有Git服务器:Soft Serve实战
运维·服务器·git
梅塔文·欧帕西安卡琼12 小时前
git的底层原理详解
git
待什么青丝12 小时前
【git的摸鱼技巧】之工欲善其事
git·elasticsearch·搜索引擎
2601_9611940213 小时前
高中英语教资资料推荐|科三大题背诵和教学设计模板
git·开源·github·开源软件·开源协议·ossinsight
ting945200013 小时前
InsForge Backend Branching 后端全链路 Git 式分支技术原理、架构实现与底层源码剖析
人工智能·git·elasticsearch·架构
程序猿阿伟13 小时前
《扣子如何让OpenClaw技能开发提速》
人工智能·git·github
摇滚侠15 小时前
IDEA 创建 Java 项目 推送到远程 Git 仓库
java·git·intellij-idea
稷下元歌16 小时前
7天学会plc加机器视觉关于运动控制部份,配套视频在bib
开发语言·c++·git·vscode·python·docker·pip
tealcwu16 小时前
【Git 实战】三类方案实现一键推送多端仓库(Gitee & GitHub)
git·gitee·github
摇滚侠16 小时前
git ignore 忽略 .idea 目录 全新项目(尚未提交过 .idea).idea 已经被 Git 跟踪(已提交过)
java·git·intellij-idea