简介
在日常开发中,代码变更比较频繁,有时候想让前几次提交的合并为一次提交,这里可以使用git rebase -i 命令来完成,当然,git rebase命令不仅仅用于合并提交,它还有许多用处,比如可以使用git rebase onto将某一段commit粘贴到另一个分支上等等,这里主要介绍合并提交。
命令介绍
rebase为变基
git rebase -i 命令可以压缩合并多次提交
格式:git rebase -i [startpoint] [endpoint]
其中-i的意思是–interactive,即弹出交互式的界面让用户编辑完成合并操作,[startpoint] [endpoint]则指定了一个编辑区间,如果不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的commit(注:该区间指定的是一个前开后闭的区间)。
在查看git的log后,可以使用如下命令
// 合并从当前head到15f745b(commit id) git rebase -i 15f745b 或: // 合并最近的两次提交 git rebase -i HEAD~2
执行这个命令后会跳到一个vi编辑器
里面的提示有:
- pick:保留该commit(缩写:p)
- reword:保留该commit,但我需要修改该commit的注释(缩写:r)
- edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e)
- squash:将该commit和前一个commit合并(缩写:s)
- fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f)
- exec:执行shell命令(缩写:x)
- drop:我要丢弃该commit(缩写:d)
实操
这里在终端输入: git rebase -i HEAD~2 这里的 HEAD~2 表示合并最近两次的提交, 如果想合并最近三次的提交修改为: git rebase -i HEAD~3
需要做的是,将第二行的 pick 改为 s, “s” 为 “squash” 的缩写,“squash” 的意思是将这个提交压缩为最后一次提交
保存后弹出这样的
将 This is the commit message #2 下面的内容改成你想提交的概述即可
最后保存退出即可
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“git rebase -i合并多次提交的实现”评论...
更新动态
2024年05月01日
2024年05月01日
- 齐秦《齐秦的世纪情歌之迷》24K GOLD [WAV+CUE][568M]
- 电子琴《汽车音响精品》5CD特效360度[WAV+CUE]
- 【古典音乐】卡拉扬《首次录音(4)》2006[FLAC+CUE整轨]
- 群星《巅峰煲碟皇·男人篇》[WAV+CUE]
- 2023年中国自研移动游戏全球流水TOP20:《原神》排名第三
- 《纸片马里奥RPG重置版》新预告 5月23日正式发售
- 蓄势待发了!开发商称对《寂静岭2RE》表现充满信心
- 梦剧院.1998-十年十美·十周年新曲+精丫乐意唱片】【WAV+CUE】
- 萧亚轩.2014-不解释亲吻【SONY】【WAV+CUE】
- 群星.2023-长风渡影视原声带【韶愔音乐】【FLAC分轨】
- 林慧萍1996-12-忘了我是女人[点将][WAV+CUE]
- 群星.2023-三体影视原声专辑【炎乐传媒】【FLAC分轨】
- 群星.2024-别对我动心影视原声带【千曜音乐】【FLAC分轨】
- 《明日方舟》联动中国电影资料馆 携手修复经典动画《铁扇公主》
- 《寂静岭2:重制版》开发商新作曝光:与T2合作开发的全新IP