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 把它"浮"到顶部,改完再换回来

相关推荐
say_fall2 小时前
Git完全入门指南-从概念到实战掌握版本控制的核心
linux·运维·服务器·git·学习
小陶来咯2 小时前
Git Cherry-Pick
git
淘矿人2 小时前
Claude助力前端开发
java·数据库·git·python·sql·spring·database
sunarmy3 小时前
在git for windows下安装pacman
git
哎呦,帅小伙哦3 小时前
Git Describe 与 TRAVIS_TAG学习笔记
笔记·git·学习
谷哥的小弟3 小时前
(最新版)Git&GitHub实操图文详解教程(04)—远程仓库GitHub
git·github·pull·push·版本管理·版本控制
weelinking7 小时前
【2026】08_Claude与版本控制:Git协作技巧
数据库·人工智能·git·python·数据挖掘·交互·cloudera
码力斜杠哥12 小时前
Git的说明及基本使用
git
摆烂且佛系12 小时前
git reset 与 git revert 区别
git