git flow图例镇楼
merge
这个简单,初学者常用。比如主分支是Dev,最新版本是01。然后小明基于此,搞了个feature 分支A,业务:打酱油。然后在上面多次提交,完成功能迭代开发,如A1 ---> A2 ---> A3.
Dev 分支 merge A,最后Dev 分支的历史就变成: Dev01 ---> A1 ---> A2 ---> A3。 Dev分支head指向最新的提交。附图如下:
rebase
中文翻译过来,变基。这个搞完,提交历史会比较清爽,哈哈。merge会有两条提交历史记录线路,有个菱形图(C3, C4, C5间关系)。rebase只有一条提交历史记录线路图,无菱形图(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