【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

相关文章

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Python3 BeautifulSoup爬虫 POJ自动提交

POJ 提交代码采用Base64加密方式 import http.cookiejarimport loggingimport urllib.parseimport urllib.requestimport base64from bs4 import BeautifulSoupfrom submitcode import SubmitCodeclass SubmitPoj():de

git ssh key相关

step1、进入.ssh文件夹   (windows下 下载git客户端)   cd ~/.ssh(windows mkdir ~/.ssh) step2、配置name和email git config --global user.name "你的名称"git config --global user.email "你的邮箱" step3、生成key ssh-keygen

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

忽略某些文件 —— Git 学习笔记 05

忽略某些文件 忽略某些文件 通过.gitignore文件其他规则源如何选择规则源参考资料 对于某些文件,我们不希望把它们纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常它们都是些自动生成的文件,比如日志文件、编译过程中创建的临时文件等。 通过.gitignore文件 假设我们要忽略 lib.a 文件,那我们可以在 lib.a 所在目录下创建一个名为 .gi

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个

Git 的特点—— Git 学习笔记 02

文章目录 Git 简史Git 的特点直接记录快照,而非差异比较近乎所有操作都是本地执行保证完整性一般只添加数据 参考资料 Git 简史 众所周知,Linux 内核开源项目有着为数众多的参与者。这么多人在世界各地为 Linux 编写代码,那Linux 的代码是如何管理的呢?事实是在 2002 年以前,世界各地的开发者把源代码通过 diff 的方式发给 Linus,然后由 Linus