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

这篇具有很好参考价值的文章主要介绍了【Git不走弯路】(二)提交与分支的本质。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 前言

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

2. 手动版本管理过程

2.1 初级版本管理

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

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

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

【Git不走弯路】(二)提交与分支的本质,Git,基础工具

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

【Git不走弯路】(二)提交与分支的本质,Git,基础工具

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

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

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

【Git不走弯路】(二)提交与分支的本质,Git,基础工具

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

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

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

2.2 进阶版本管理

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

【Git不走弯路】(二)提交与分支的本质,Git,基础工具

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

【Git不走弯路】(二)提交与分支的本质,Git,基础工具

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

【Git不走弯路】(二)提交与分支的本质,Git,基础工具

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

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

3. Git版本管理

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

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

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

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

4. 结语

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

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


本文原创发布于Qt未来工程师。文章来源地址https://www.toymoban.com/news/detail-816792.html

到了这里,关于【Git不走弯路】(二)提交与分支的本质的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 如何少走弯路?蚓链助力零售企业实现数字化转型

    基于大环境下的数据驱动,创新业务模式成为了后疫情时代下零售企业冲破困局、拓展业务的必然趋势,新零售概念应运而生。新零售结合数字化应用技术为传统零售企业打造线上营销生态链,帮助企业积累数据,盘活数据实现更大营收价值。 消费市场日益剧增,但品类本身

    2024年02月15日
    浏览(28)
  • Java开发 - 让你少走弯路的Redis的主从复制

    大家举举手,让我看看还有多少人不会配置Redis的主从,主主这些的。故事发生在前段时间,小伙伴看到了博主的MySQL主从,就问博主有没有Redis的主从配置教程,本以为网上到处都是教程的博主打开网页一搜,好家伙,多是多,就是没几个讲的清楚明白,还有不少是错误的配

    2024年02月07日
    浏览(27)
  • 功能测试进阶自动化测试如何摸清学习方向,少走弯路呢?

    目录 抛开疑问,只做学术探讨 小白在想什么? 盖楼之前先打好地基,首先需要学习一门语言 语言入门后,正式踏上开始自动化成神之路,入门篇Selenium 玩腻了Selenium 开始接触自动化框架unittest/testNG 不满足于单元测试框架的功能 学习自动化框架 初始接口测试 尝试学习Requ

    2024年02月13日
    浏览(53)
  • Java开发 - 让你少走弯路的Redis主从实现单节点哨兵模式

    前一篇中,我们讲解了Redis主从的搭建方式,其实很简单呐有木有,都是配置,连句代码都没有,是不是感觉高估了Redis主从的搭建方式?哈哈,没关系,跟着博主,包你全会。今天我们的主题是哨兵,没错,就是哨兵!有了Redis,要是没有哨兵,那真是太可惜了,哨兵是很神

    2024年02月07日
    浏览(31)
  • 想转行DevOps工程师?快来看看DevOps工程师的学习路径,少走弯路

    :::tips DevOps方法论的主要来源是Agile, Lean 和TOC, 独创的方法论是持续交付。 ::: DevOps 是一种软件开发方法,涉及持续开发,持续测试,持续集成,部署和监视。这一系列过程跨越了传统上孤立的开发和运营团队,DevOps 试图消除它们之间的障碍。 因此,DevOps 工程师基本上与 D

    2024年02月08日
    浏览(33)
  • 干货分享:AI绘图学习心得-Midjourney绘画AI,让你的AI绘画之路少走弯路

    本篇没有什么长篇大论,全部都是实用心得总结。接下来,我们将分享关于Midjourney绘画AI的实用心得总结,包括构图指令结构、常用指令、操作技巧、常用风格词汇和构图词汇。 如果你想入门MidJourney可以查看这篇教程:Midjourney最全操作指南,从入门到精通 AI绘画的核心就是

    2024年02月11日
    浏览(38)
  • 一篇文章彻底了解网络字节序和主机字节序,初学者进来,不走弯路

    目录 1.什么是字节序? 2.大端字节序和小端字节序 3.主机字节序和网络字节序 4.不同类型数据传输处理流程对比 5.设计一个小程序来判断当前机器的字节序? 6.大小端转换方法? 字节序,字节在内存中排列顺序 计算机存储数据方式是从内存增长方向存储 图 1 计算机存储方式 网

    2024年02月03日
    浏览(35)
  • 腾讯前辈熬夜肝了一个月整理的《Linux内核学习笔记》,啃完受益匪浅不走弯路

    小编热衷于收集整理资源,记录踩坑到爬坑的过程。希望能把自己所学,实际工作中使用的技术、学习方法、心得及踩过的一些坑,记录下来。也希望想做Linux内核高级工程师的你一样,通过我的分享可以少走一些弯路,可以形成一套自己的方法,并应用到实际中。 1.了解操

    2023年04月14日
    浏览(29)
  • Git 分支操作详解:创建、提交、合并主分支

            Git 是一款强大的分布式版本控制系统,分支是其核心特性之一,为团队协作和项目管理提供了灵活性。本文将介绍 Git 分支的基本用法,包括创建分支、提交更改、合并主分支等操作。 1、 创建分支         在 Git 中,分支是项目开发的不同线路,它们允许团

    2024年02月05日
    浏览(51)
  • 【git常用操作】git的分支创建、切换、提交与关联分支操作

    下拉代码建议用ssh密钥方式下拉 ,配置好之后后续操作不需要输入密码等权限验证操作,很方便。 查看分支: 创建本地分支: 切换本地分支: 创建+切换分支: 将新分支推送到github: 建议使用IDEA集成git来完成下列操作 ,如果使用上面提到的ssh密钥方式下拉工程的话会方便

    2024年02月15日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包