【Git不走弯路】(二)提交与分支的本质

2024-01-22 16:28

本文主要是介绍【Git不走弯路】(二)提交与分支的本质,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 前言

提交与分支是Git中两个基本对象,对初学者而言需要花些时间理解。正如我们之前所说,计算机中很多新概念是新瓶装旧酒。计算机技术来源于需求,服务于需求,需求是计算机技术的出发点和落脚点。梳理清楚工程实践中,版本管理工作的每个需求点和细节,就能摸清Git的来龙去脉。

2. 手动版本管理过程

2.1 初级版本管理

某高校软件开发团队,简称A团队,承接了一个商品管理系统项目,名为ProductManager

通过紧锣密鼓的开发,一个月后,基本功能开发完成,发送客户确认后,客户比较满意。并提出了改进意见。

此时A团队的代码目录如下所示:

基础代码目录

此时,项目负责人小张并没有直接开展项目改进工作,为了巩固团队开发成果,防止后续修改出现问题无法回退到当前的源码状态,小张将此时的代码复制了一份,将其命名为 ProjectManager V1.0,至此,第一个版本诞生了:

第一个版本诞生

此后,开发团队可以在 ProductManager 源码目录中继续开发,而不会影响目录 ProductManager V1.0。想要在任意时刻恢复某个文件,只需要将其从ProductManager V1.0 中拷贝出来进行文件替换即可完成恢复操作。通过创建版本,实现了将文件回退到过去某个状态的效果。

经过一段时间改进后,软件被发送给客户使用,客户觉得软件界面样式还是改进前的好看,于是提出恢复以前的界面样式。由于开发团队创建了 V1.0 版本的备份,所以可以轻松的将以前皮肤的代码提取出来,替换当前皮肤。手中有版本,心中绝不慌。

为了防止客户再次反悔以及应对各种各样的代码恢复问题,小张决定,团队每次修改一个功能,都需要进行备份。于是产生了很多备份版本:

产生了诸多备份版本

以上备份文件夹我们称之为“提交”。

由于版本很多,备份的数据占用了很大的磁盘空间,这是手动版本管理方式的缺点之一。实际上,版本与版本之间,并不是所有文件都有变化,所以按照文件夹进行完全拷贝式备份,有很多文件是完全相同的,也就是存在冗余备份。如果只对版本与版本之间,差异的文件进行备份,简称“差异备份”,这样肯定会节省很大的空间,但是会增加人工管理成本,没有直接全部拷贝简单直接。

另外,版本与版本之间究竟修改了哪些内容,修改的目的是什么,都没有进行记录,不够规范,没有统一版本管理标准。如果缺少版本描述,会增版本的使用难度。

2.2 进阶版本管理

在 V3.0 版本开始,客户要求,软件需要提供两个版本,分别提供给两个 超市A超市B 使用。分别基于V3.0版本,针对两个超市的实际需求,继续完善软件。针对这样的需求,小张决定新建两个文件夹来保存两个超市的软件代码和各自的备份版本,分别叫 SuperMarketA,SuperMarketB,如下所示:

进阶阶段源码目录

在随后的开发过程中,SuperMarketASuperMarketB 独立进行版本备份,互不影响,一段时间后,版本结构如下:

AB各自独立维护版本线

SuperMarketA 和 SuperMarketB 不是一个具体的备份,而是一系列连续备份的集合,我们称之为 “分支”。分支示意图如下:

分支名称

其中,初级阶段的所有提交所在的分支,默认称之为 “master分支”。

以上只是最简单的版本管理过程,实际工程中的版本管理场景及需求更加复杂。正因为如此,手动版本管理无法胜任复杂的软件开发工作,工程实践中,已被 版本管理软件 所替代。

3. Git版本管理

Git是一款免费开源的版本管理软件,用以替代手动版本管理,克服手动版本管理的不足。它完善了版本管理理论,统一了版本管理规范,能够满足各种版本管理需求。以上提到的 “提交”,“分支”,正是Git中的数据对象。

通过手动版本管理过程,我们发现:

“提交”,“分支” 的本质,其实就是(手动版本管理过程中的)备份文件夹 (注意此处是名词)。

Git提供给使用者的绝大部分功能,就是在操作 “提交”、“分支” 这两个数据对象。如果不能很好的理解这两个关键对象,学习Git命令就会比较困难。操作 “提交”、“分支”,可以类比为操作备份文件夹,二者形式上有所不同,但是本质上相同。

4. 结语

没有魔法,提交与分支的本质就是备份文件夹。

后续文章中,我们将以使用文件夹操作来模拟Git操作的思路,形象分析Git中的基本操作的具体含义。


本文原创发布于Qt未来工程师。

这篇关于【Git不走弯路】(二)提交与分支的本质的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

IDEA实现回退提交的git代码(四种常见场景)

《IDEA实现回退提交的git代码(四种常见场景)》:本文主要介绍IDEA实现回退提交的git代码(四种常见场景),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.已提交commit,还未push到远端(Undo Commit)2.已提交commit并push到

MySQL中的两阶段提交详解(2PC)

《MySQL中的两阶段提交详解(2PC)》:本文主要介绍MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言两阶段提交过程sync_binlog配置innodb_flush_log_at_trx_commit配置总结引言在Inn

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

IDEA中Git版本回退的两种实现方案

《IDEA中Git版本回退的两种实现方案》作为开发者,代码版本回退是日常高频操作,IntelliJIDEA集成了强大的Git工具链,但面对reset和revert两种核心回退方案,许多开发者仍存在选择... 目录一、版本回退前置知识二、Reset方案:整体改写历史1、IDEA图形化操作(推荐)1.1、查看提

Git如何修改已提交人的用户名和邮箱

《Git如何修改已提交人的用户名和邮箱》文章介绍了如何修改Git已提交人的用户名和邮箱,包括注意事项和具体步骤,确保操作正确无误... 目录git修改已提交人的用户名和邮箱前言第一步第二步总结git修改已提交人的用户名和邮箱前言需注意以下两点内容:需要在顶层目录下(php就是 .git 文件夹所在的目

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复