有识

个人网 | 追寻一切真知灼见

用户工具

站点工具


侧边栏

博主公告

想读书,想旅游,想运动,但是没有时间?其实我们不是没有时间,只是没有真正把想做的事情,放在重要的位置上,或者干脆没时间搞清楚到底那件事情对你来说更重要。^_^ 欢迎大家收看《程序员带你学打羽毛球》 和博主一起加入运动的行列。 ease 11:53 - 08月02日




最新博文》更多博文

分类索引

博主简介
吕某某 Leo
河北人,网名:ease
资深IT菜鸟,创业者
兴趣爱好:
人工智能,运动,读书,coding
人生格言:
命由己造 相由心生 有容乃大 无欲则刚 》博主管理》关于博主


blog:ease:git:git-basic10

变基

概念:

代码整合:merge 和 rebase 一个是合并,一个叫“变基”
通过图片来看什么是变基:

1 基础例子

两个分支合并的提交历史。 通过变基。变成线性的提交历史。 (上图例子)

变基的原理:临时保存一个分支的提交差异。 然后调整当前分支,最后再逐个应用差异。 参考: https://git-scm.com/book/zh/v2/Git-%E5%88%86%E6%94%AF-%E5%8F%98%E5%9F%BA

2 变基的目的:保持提交历史的整洁。

变基的应用场景: 像别人维护的项目贡献代码时

  1. 自己首先在自己本地进行各种分支操作开发。
  2. 开发完毕,变基到origin/master 然后提交。

否则你的 ease 分支将会是很多分支合并的结果。包含了很多枝节。通过变基,则你只会推送上去一个线性的记录。管理者也方便进行查看应用你的修改。

3 一个更有(tou)趣(tong)的例子

(限于篇幅,还是考虑省掉了这个例子) git rebase –onto master server client 选中 在 client 分支上的修改,并且不在 server 做处的修改(c3) 基于master 变基。 注意这里的关键是 选中的修改 是 server 和 client 的差异。 参考:https://git-scm.com/book/zh/v2/Git-%E5%88%86%E6%94%AF-%E5%8F%98%E5%9F%BA

4 变基冲突解决

案例 :两个分支都修改了同一行代码。 然后进行变基操作。

....
冲突(内容):合并冲突于 f1.py
error: 无法合并变更。
打补丁失败于 0001 f1 444
失败的补丁文件副本位于:.git/rebase-apply/patch

当您解决了此问题后,执行 "git rebase --continue"。 注意之前先 git add .
如果您想跳过此补丁,则执行 "git rebase --skip"。
要恢复原分支并停止变基,执行 "git rebase --abort"。

5 变基的原则 && 风险

变基应用领域,通常是为了给比人贡献代码的时候,整理代码用的。

原则:

变基的仓库只此一份,如果这个仓库有其他副本。比如有和其他人分享代码。那么不要进行变基操作。总的原则是,只对尚未推送或分享给别人的本地修改执行变基操作清理历史,从不对已推送至别处的提交执行变基操作,这样,你才能享受到两种方式带来的便利。(多人协作时将会造成混乱) 除非所有人都:git pull –rebase 如果已经有问题,这是缓解之道。但不能彻底解决问题。(不建议!)

blog/ease/git/git-basic10.txt · 最后更改: 03:42 - 09月02日 (外部编辑)