前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Git之rebase、merge和cherry pick的区别详解—面试常问

Git之rebase、merge和cherry pick的区别详解—面试常问

作者头像
NaughtyCat
发布2020-10-09 16:45:33
1.8K0
发布2020-10-09 16:45:33
举报
文章被收录于专栏:开心的平凡酱开心的平凡酱

git flow 镇楼

转载请注明出处:https://www.cnblogs.com/NaughtyCat/p/differ-with-rebase-merge-cherry-pick.html

  • merge

这个简单,初学者常用。比如主分支是Dev,最新版本是01。然后小明基于此,搞了个feature 分支A,业务:打酱油

然后在上面多次提交,完成功能迭代开发,如A1 ---> A2 ---> A3(作者【CoderBaby】)

Dev 分支 merge A branch,最后Dev 分支的历史log就变成: Dev01 ---> A1 ---> A2 ---> A3

附图如下:

  • rebase

中文翻译过来,变基。这个搞完,提交历史会比较清爽,哈哈

a)  merge会有两条提交历史记录线路,有个菱形图(C2, C3, C4, C5间关系)

b)rebase只有一条提交历史记录线路图,无菱形图(C2, C3, C4'),并且少了一个提交对不,C4好像不存在

附图如下:

                         after merge 


                         after rebase

官网说明请移步: https://git-scm.com/book/en/v2/Git-Branching-Rebasing

rebase、merge的区别参见: https://stackoverflow.com/questions/16666089/whats-the-difference-between-git-merge-and-git-rebase

  • cherry pick

直译,摘樱桃。这个就是可以选一个分支中一个或者几个commit来应用提交到另外一个分支,操作单元是commit 不是branch。附图如下:

当前分支head 指向F,我可以选取另一个分支上的C commit,将其更改应用到我的分支,作为C‘ commit。

官网说明请移步:  https://git-scm.com/docs/git-cherry-pick

附:

git官网中文版电子书(web版):  https://git-scm.com/book/zh/v2

*****************************************************************************************************

精力有限,想法太多,专注做好一件事就行

  • 我只是一个程序猿。5年内把代码写好,技术博客字字推敲,坚持零拷贝和原创
  • 写博客的意义在于锻炼逻辑条理性,加深对知识的系统性理解,锻炼文笔,如果恰好又对别人有点帮助,那真是一件令人开心的事

*****************************************************************************************************

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档