Git系列:git merge 使用技巧


在这里插入图片描述
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
在这里插入图片描述

  • 推荐:「stormsha的主页」👈,持续学习,不断总结,共同进步,为了踏实,做好当下事儿~
  • 专栏导航
    • Python面试合集系列:Python面试题合集,剑指大厂
    • GO基础学习笔记系列:记录博主学习GO语言的笔记,该笔记专栏尽量写的试用所有入门GO语言的初学者
    • 数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 运维系列:总结好用的命令,高效开发
    • 算法与数据结构系列:总结数据结构和算法,不同类型针对性训练,提升编程思维

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

💖The Start💖点点关注,收藏不迷路💖

📒文章目录

  • Git Merge 技巧:高效合并代码的艺术
    • 1. 理解 Git Merge 的基础
      • 1.1 快进合并(Fast-forward Merge)
      • 1.2 三方合并(Three-way Merge)
    • 2. 使用 `--no-ff` 选项
    • 3. 合并策略
      • 3.1 策略选项
    • 4. 处理合并冲突
      • 4.1 使用图形化工具
      • 4.2 手动解决冲突
    • 5. 合并多个分支
    • 6. 保持历史清洁
      • 6.1 使用 `rebase`
      • 6.2 压缩小的提交
    • 7. 使用 `ours` 或 `theirs` 解决冲突
    • 8. 避免合并提交
    • 结语


在这里插入图片描述

Git Merge 技巧:高效合并代码的艺术

在软件开发中,git merge 是一个常用的命令,用于将不同的代码分支合并在一起。掌握一些高级的合并技巧,可以帮助开发者更高效地进行代码整合。以下是一些中高级的 git merge 使用技巧,旨在帮助开发者提升代码合并的效率和质量。

git merge 命令的参数包括:

  • --no-ff: 当合并时创建一个新的合并提交,即使当前分支是快进合并。
  • --squash: 将所有合并的提交压缩成一个单一的提交。
  • --strategy: 指定合并策略,如 recursive(递归,默认策略)、resolve(解决)、octopus(八爪鱼,用于多分支合并)。
  • --ours: 使用当前分支的版本,忽略其他分支的更改。
  • --theirs: 使用被合并分支的版本,忽略当前分支的更改。
  • --abort: 中止一个正在进行的合并过程。
  • --continue: 在解决冲突后继续合并过程。
  • -m <message>: 为创建的合并提交指定提交信息。
  • --no-edit: 不编辑合并提交信息,使用默认信息。
  • --no-commit: 不创建合并提交,将更改放在暂存区和工作目录中。
  • --quiet: 减少命令输出的详细程度。

1. 理解 Git Merge 的基础

在深入技巧之前,理解 git merge 的基础是必要的。git merge 命令用于将两个或多个开发历史合并在一起。

1.1 快进合并(Fast-forward Merge)

当两个分支的提交历史是线性的时候,Git 可以执行快进合并,即直接将一个分支的指针移动到另一个分支的顶部。

1.2 三方合并(Three-way Merge)

当两个分支有共同的祖先,但是已经分叉了一段时间,Git 会创建一个新的“合并提交”(merge commit),它有多个父提交,分别指向两个分支的末端。

2. 使用 --no-ff 选项

在默认情况下,如果合并可以执行快进,Git 会这样做。但是,有时候我们希望即使在快进合并的情况下也创建一个新的合并提交。这时可以使用 --no-ff 选项。

git merge --no-ff branch-name

3. 合并策略

Git 提供了不同的合并策略,可以通过 -c--config 选项来设置。

3.1 策略选项

  • resolve:当有冲突时,尝试自动解决。
  • recursive:默认策略,适用于大多数情况。
  • octopus:允许同时合并多个分支。
git merge -c strategy-name branch-name

4. 处理合并冲突

合并冲突是合并过程中常见的问题,以下是一些处理冲突的技巧。

4.1 使用图形化工具

使用图形化的合并工具可以更直观地查看和解决冲突。

git mergetool

4.2 手动解决冲突

有时候,手动编辑冲突的文件并解决冲突是必要的。解决后,需要标记文件为已解决。

git add resolved-file

5. 合并多个分支

有时需要将多个分支的更改合并到一个分支中。可以使用 git merge 的多次合并。

git merge branch1 branch2 branch3

6. 保持历史清洁

在合并之前,确保分支历史是清洁的,可以提高合并的效率。

6.1 使用 rebase

git rebase 可以重新定位一系列提交,使其在另一个分支的顶部。

git rebase main feature-branch

6.2 压缩小的提交

使用 git rebase -i 可以交互式地重写提交历史,合并小的提交,使历史更加清晰。

git rebase -i HEAD~N

7. 使用 ourstheirs 解决冲突

在某些情况下,你可能希望在冲突中优先使用某一方的更改。

git checkout --ours file-with-conflict

或者

git checkout --theirs file-with-conflict

8. 避免合并提交

在某些情况下,你可能不希望在合并时创建一个新的合并提交。

git merge --squash branch-name

这将把所有的更改合并到一个单一的提交中。

结语

掌握 git merge 的高级技巧对于任何开发者来说都是一项宝贵的技能。通过上述的技巧,你可以更高效地合并代码,减少合并冲突,保持项目历史的清晰。记住,实践是学习的最佳方式,所以不要害怕尝试不同的方法,找到最适合你的工作流程。


❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏、分享下吧,非常感谢!👍 👍 👍

🔥🔥🔥道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

💖The End💖点点关注,收藏不迷路💖

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3018861.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

基于springboot实现体育馆管理系统项目【项目源码+论文说明】

基于springboot实现体育馆管理系统演示 摘要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本体育馆管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理…

2024高安全个人密码本程序源码,贴身密码管家-随机密码备忘录二代密码

项目概述&#xff1a; 在这个网络高度发展的时代&#xff0c;每个人都需要上网&#xff0c;而上网就不可避免地需要使用账号和密码。 在众多账号的情况下&#xff0c;你是否还在为复杂难记的密码感到烦恼&#xff1f;现在只需要记录一次&#xff0c; 就可以随时查看你的密码…

代码随想录算法训练营第二十天:二叉树成长

代码随想录算法训练营第二十天&#xff1a;二叉树成长 110.平衡二叉树 力扣题目链接(opens new window) 给定一个二叉树&#xff0c;判断它是否是高度平衡的二叉树。 本题中&#xff0c;一棵高度平衡二叉树定义为&#xff1a;一个二叉树每个节点 的左右两个子树的高度差的绝…

提升Go语言数学运算能力:math包使用指南

提升Go语言数学运算能力&#xff1a;math包使用指南 介绍数学函数的使用基本数学运算幂和根的计算三角函数对数计算 特殊数学常数和函数数学常数超越数学函数错误处理和精度问题 高级应用实例统计数据的标准偏差计算利用三角函数解决实际问题 性能优化技巧避免不必要的函数调用…

数学建模资料|历年数维杯数学建模竞赛真题及获奖论文汇总

2024年第九届数维杯大学生数学建模挑战赛:2024年5月10日08:00-5月13日09:00举行,为了更好的帮助参赛同学了解竞赛的赛制及赛题特点,数乐君今天给大家整理了历年数维杯国赛真题及优秀论文,方便同学们赛前巩固训练,掌握解题方法,提高获奖率。 2023年数维杯国赛真题(ABC题…

K邻算法:在风险传导中的创新应用与实践价值

01 前言 在当今工业领域&#xff0c;图思维方式与图数据技术的应用日益广泛&#xff0c;成为图数据探索、挖掘与应用的坚实基础。本文旨在分享嬴图团队在算法实践应用中的宝贵经验与深刻思考&#xff0c;不仅促进业界爱好者之间的交流&#xff0c;更期望从技术层面为企业在图数…

【JavaEE 初阶(三)】多线程代码案例

❣博主主页: 33的博客❣ ▶️文章专栏分类:JavaEE◀️ &#x1f69a;我的代码仓库: 33的代码仓库&#x1f69a; &#x1faf5;&#x1faf5;&#x1faf5;关注我带你了解更多线程知识 目录 1.前言2.单例模式2.1饿汉方式2.2饿汉方式 3.阻塞队列3.1概念3.2实现 4.定时器4.1概念4.…

【服务治理中间件】consul介绍和基本原理

目录 一、CAP定理 二、服务注册中心产品比较 三、Consul概述 3.1 什么是Consul 3.2 Consul架构 3.3 Consul的使用场景 3.4 Consul健康检查 四、部署consul集群 4.1 服务器部署规划 4.2 下载解压 4.3 启动consul 五、服务注册到consul 一、CAP定理 CAP定理&#xff…

【Python】一道字典题目

题目&#xff1a;输入一段文本&#xff0c;统计每个字符的个数 in_inputinput(“输入&#xff1a;”) dic{} for char in in_input: if char in dic: dic[char]1 # 字典添加键值对的方法&#xff0c;给字典给键和值的方法 else: dic[char]1 print(dic) 输出台&#xff1a;

胖东来启动帮扶永辉超市

图来源&#xff1a;大河报。 5月7日晚间&#xff0c;据《联商网》报道&#xff0c;胖东来将启动对中国商超巨头永辉超市展开帮扶调改。这也是继帮扶嘉百乐和步步高超市之后&#xff0c;胖东来再次向传统商超伸出援手。 胖东来再出手 启动帮扶调改永辉超市 5月5日-6日&#x…

使用Maven对Java独立应用程序进行编译打包

一、 安装Maven 1.解压&#xff0c;移动安装包 sudo tar -zxf ~/apache-maven-3.9.6-bin.tar.gz -C /usr/local/ cd /usr/local/ sudo mv apache-maven-3.9.6/ ./maven-3.9.6 sudo chown -R qiangzi ./maven-3.9.6 二、Java应用程序代码 1.版本信息&#xff1a; Spark-2.1…

QT实现Home框架的两种方式

在触摸屏开发QT界面一般都是一个Home页面&#xff0c;然后button触发进入子页面显示&#xff0c;下面介绍这个home框架实现的两种方式&#xff1a; 1.方式一&#xff1a;用stackedWidget实现 &#xff08;1&#xff09;StackedWidget控件在Qt框架中是一个用于管理多个子窗口或…

酷开科技 |酷开系统,给家里多点乐趣~

作为家庭娱乐的核心枢纽&#xff0c;酷开系统致力于为每一个家庭带来更多的乐趣和欢笑。通过其智能化的设计和个性化的服务&#xff0c;酷开系统正在逐渐改变家庭娱乐的方式&#xff0c;让客厅成为家中温馨的娱乐中心。 首先&#xff0c;酷开系统的界面友好而直观&#xff0c;…

SpringBoot使用AOP注解记录操作日志

一、前言 日志&#xff1a;指系统所指定对象的某些操作和其操作结果按时间有序的集合。 操作日志&#xff1a;主要是对某个对象进行新增操作或者修改操作后记录下这个新增或者修改&#xff0c;操作日志要求可读性比较强。比如张三在某个时间下了订单买了某个商品&#xff01; …

【uniapp】阿里云OSS上传 [视频上传]

引用uniapp插件市场的插件,使用的是视频上传 &#xff08;阿里云 oss上传&#xff09; 我只使用了H5和App端&#xff0c;需要后端配置跨域 yk-authpup详情请参考 》》【用户告知权限申请的目的】 【插件市场】阿里云存储OSS前端直接上传(全端通用) - 前端JASON <template>…

Linux主机排查工具-GScan

0x01 简介 本程序旨在为安全应急响应人员对Linux主机排查时提供便利&#xff0c;实现主机侧Checklist的自动全面化检测&#xff0c;根据检测结果自动数据聚合&#xff0c;进行黑客攻击路径溯源。 0x02 项目地址 https://github.com/grayddq/GScan 0x03 CheckList检测项 自…

FTP-自用

一、登录 1、ftp服务器搭建 liunx&#xff1a;FTP服务器的搭建&#xff08;Linux&#xff09;_linux搭建ftp服务器-CSDN博客windows&#xff1a;搭建FTP服务器_ftp服务器搭建-CSDN博客 2、连接ftp服务器 ftp ip地址ftp 域名 注&#xff1a;长时间不操作自动退出 二、常用命…

rust容器、迭代器

目录 一&#xff0c;std容器 1&#xff0c;Vec&#xff08;向量、栈&#xff09; 2&#xff0c;VecDeque&#xff08;队列、双端队列&#xff09; 3&#xff0c;LinkedList&#xff08;双向链表&#xff09; 4&#xff0c;哈希表 5&#xff0c;集合 6&#xff0c;Binary…

带你一键解析微信小程序微信支付详细流程(包括开发流程+Cpolar安装+获取公网ip方法)

微信支付流程 前言微信支付方式接入流程微信支付在开发中的流程JSAPI下单小程序调起支付API开发准备Cpolar下载安装 我的代码实例总结 前言 &#x1f514;大多数小伙伴是不是还在好奇微信支付在我们的开发端是如何实现的&#xff0c;其实微信支付的技术我们直接通过引用就能完…

抢占用户|AI助力企业高效挖掘潜在客户,推动高质量转化

随着人工智能&#xff08;AI&#xff09;技术的崛起&#xff0c;企业终于可以在这个数字化时代获得一种强大的工具&#xff0c;帮助企业迅速而准确地找到潜在客户。AI不仅能够处理海量的数据&#xff0c;还能自动分析和识别潜在客户的特征和行为模式&#xff0c;为企业营销提供…