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 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson3 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友3 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金4 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森4 天前
Git 基础筑基:从原理到团队协作的全栈实战
git
JakeJiang5 天前
Git 必备命令指南:从日常高频到项目开发实战
git
叫我少年5 天前
Windows 中安装 git
git
深海鱼在掘金11 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc11 天前
关于Git Flow
git
蜜獾云11 天前
在Git中配置用户名和密码
git