当前位置: 首页 > news >正文

【git】rebase 和 merge 区别及使用建议

区别

特性MergeRebase
历史记录保留所有分支历史,生成合并提交改写历史,线性化提交
提交树保留分支结构,可能复杂线性历史,简洁
冲突处理一次性解决合并冲突可能多次解决(每个提交)
适用场景团队协作,公开分支个人分支整理,追求干净历史

效果

merge

A --- B --- C (main)\D --- E (feature)
合并后:
A --- B --- C --- F (main, F 是合并提交)\         /D --- E (feature)

在这里插入图片描述

rebase

A --- B --- C (main)\D --- E (feature)
Rebase 后:
A --- B --- C --- D' --- E' (main)

在这里插入图片描述

使用建议

  • 公司项目:一般推荐使用 git merge,可以看到完整的 git 提交历史,即使提交历史会比较乱。具体看公司要求。
  • 个人项目:不想麻烦,直接使用 git merge 也可以,追求提交历史简洁使用 git rebase

tips

  • 无论是 merge 还是 rebase,都不会改变代码修改人,都可以在 idea 里面看到代码的作者是谁。只不过 rebase 会改变提交历史。
    • 比如张三从 master 拉了 dev 分支,开发完重新合并到 master 分支。
    • 通过 merge 你可以看到张三从 master 拉了 dev 分支,然后又合并到了 master 分支。而 rebase 后,你无法看到从 master 拉了 dev 分支,然后又合并到了 master 分支。rebase 后,提交历史会变成一条直线,看着比较整洁。
http://www.dtcms.com/a/528552.html

相关文章:

  • 机器学习催化剂设计!
  • Agent Zero:重新定义AI Agent的有机生长框架——从“预设工具“到“自我进化“的范式革命
  • 脚本更新--CosMx、Xenium的邻域通讯分析(R版本)
  • VS Code搭建C/C++开发调试环境-Windows
  • 怎么把自己做的网站发布到网上网站建设专题页面
  • 面向智慧农业的自主移动果蔬采摘机器人:融合视觉识别与自动驾驶的智能化农作系统研究
  • 厦门专业网站设计公司低价网站建设推广优化
  • ClickHouse 介绍
  • 何时在 ClickHouse 中使用 ARRAY JOIN
  • Stream流中.filter和.map的用法区别
  • 在万网上域名了怎么做网站网页设计与制作工资多少
  • 哈尔滨网站建设制作费用百度推广销售
  • FireFox如何滚动截屏?
  • 【Linux】Tomcat基本配置
  • 网站建设的系统分析有哪些好的建站平台
  • 【大模型推理】ScheduleBatch 学习
  • 【经典书籍】C++ Primer 第19章特殊工具与技术精华讲解
  • JAVA面试汇总(二)多线程(五)
  • 怎样设计网站模板网站 建设初步
  • 网站建设所需的硬件设备网站运营工作是干什么的
  • 网站中的表格wordpress后台404
  • 从零开始:C++ 多进程 TCP 服务器实战(续篇)
  • 阮一峰《TypeScript 教程》学习笔记——装饰器
  • 一、基础预训练模型与能力
  • 上海网站建设选缘魁-企查公司简介模板文案
  • 重磅新书 | 《链改2.0:从数字资产到RWA》
  • 【IOS开发】SwiftUI + OpenCV实现图片的简单处理(一)
  • 【Docker】docker run
  • 成都网站建设 Vr便民网
  • LLama3架构原理浅浅学学