Git 实践笔记

这里写自定义目录标题

一、将当前改动追加到某次commit上

  1. stash工作区中的当前改动 git stash
  2. 假设需要修改的commit是 f744c32,将HEAD移动到需要改动的commit的父提交上 git rebase f744c32^ --interactive,找到需要更改的commit,将行首的 pick 改成 edit,保存退出。

注意这个f744c32^,表示f744c32的父提交。这里有个前提:如果你想修改f744c32这个提交本身,就需要rebase到它的父提交。假设提交历史如下:

c 复制代码
A - B - C - D(HEAD) 

如果你想修改 B、C、D,用git rebase B^ --interfacegit rebase A --interface

  1. 执行命令 git stash pop
  2. 使用 git add 改动的文件 将改动文件添加到暂存区
  3. 使用 git commit --amend追加改动到第2步中指定的commit上
  4. 使用 git rebase --continue 移动HEAD到最新的commit处
    第3步中 pick 变 edit和第5步如果产生冲突,都会使变基操作暂停。如果有冲突会在这一步体现出来,手动解决冲突后,再次执行 git rebase --continue 即可完成rebase,以及针对目标commit的修改。
  5. 使用 git branch -f 分支名 HEAD 将本地分支强行切换到rebase后的头上。
    备注:使用 cat .git/HEAD 查看当前HEAD的指向

二、git 强制修改分支位置

git branch -f release_V6.5.0.0 HEAD~3
git branch -f release_V6.5.0.0 具体commit的哈希值

相关推荐
三水不滴4 小时前
计网ping原理
经验分享·笔记·计算机网络
prog_61034 小时前
【笔记】思路分享:各种大模型免费当agent后台
笔记·大语言模型·agent·cursor
凯尔萨厮5 小时前
Maven(Windows下载安装)
笔记·maven
wdfk_prog5 小时前
[Linux]学习笔记系列 -- [drivers][input]serio
linux·笔记·学习
先跑起来再说5 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
菩提小狗6 小时前
小迪安全2023-2024|第5天:基础入门-反弹SHELL&不回显带外&正反向连接&防火墙出入站&文件下载_笔记|web安全|渗透测试|
笔记·安全·web安全
Wentao Sun6 小时前
致敬软件创业者2026
笔记·程序人生
深蓝海拓7 小时前
PySide6,QCoreApplication::aboutToQuit与QtQore.qAddPostRoutine:退出前后的清理工作
笔记·python·qt·学习·pyqt
酒鼎7 小时前
学习笔记(3)HTML5新特性(第2章)
笔记·学习·html5
山岚的运维笔记8 小时前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver