zoukankan      html  css  js  c++  java
  • git merge和git rebase的区别

    git merge是用来合并两个分支的。
    # 将b分支合并到当前分支
    git merge b

    git cherry-pick可以选择某一个分支中的一个或几个commit(s)来进行操作。例如,假设我 们有个稳定版本的分支,叫v2.0,另外还有个开发版本的分支v3.0,我们不能直接把两个分支合并,这样会导致稳定版本混乱,但是又想增加一个v3.0 中的功能到v2.0中,这里就可以使用cherry-pick了。

    # 先在v3.0中查看要合并的commit的commit id
    git log
    # 假设是 commit f79b0b1ffe445cab6e531260743fa4e08fb4048b

    # 切到v2.0中
    git check v2.0

    # 合并commit
    git cherry-pick f79b0b1ffe445cab6e531260743fa4e08fb4048b

    git rebase有点类似git merge,但是两者又有不同,打个比方,你有两个抽屉A和B,里面都装了衣服,现在想把B中的衣服放到A中,git merge是那种横冲直撞型的,拿起B就倒入A里面,如果满了(冲突)再一并整理;而git rebase就很持家了,它会一件一件的从B往A中加,会根据一开始放入的时间顺序的来加,如果满了你可以处理这一件,你可以继续加,或者跳过这一件,又 或者不加了,把A还原。所以merge适合那种比较琐碎的,简单的合并,系统级的合并还是用rebase吧。

    专业的区别请移步到这里合并和衍合

    # 合并b
    git rebase b

    # 处理完冲突继续合并
    git rebase –continue

    # 跳过
    git rebase –skip

    # 取消合并
    git rebase –abort
  • 相关阅读:
    制作 MarkText 的导航栏和动画背景
    某雅互动静态页面
    html5 拖拽及用 js 实现拖拽
    九宫格
    phaser3 入门实例——收集星星游戏
    Flexbox Froggy:练习 Flex 布局的小游戏
    JS30
    ElasticSearch
    JVM
    jstack命令的使用
  • 原文地址:https://www.cnblogs.com/wxcbg/p/6366258.html
Copyright © 2011-2022 走看看