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

git -- 版本控制介绍(分布式系统),git介绍(对待数据的方式,本地执行,保证完整性,只添加数据,git文件/项目的三种状态,基本的工作流程)

目录

版本控制

介绍

分布式版本控制系统

 git

介绍

与多个远程仓库协作

对待数据的方式

本地执行操作

保证完整性

只添加数据

三种状态

工作区

暂存区

Git 目录

 基本的git工作流程


版本控制

介绍

一种记录一个或多个文件内容变化的系统,它可以让你在未来的某个时间点查阅、还原或对比特定版本的文件或项目状态

  • 这对于协作开发、代码审查、Bug 追踪等都非常重要
  • 并且,就算你乱来一气把整个项目中的文件改的改删的删,你也照样可以轻松恢复到原先的样子。 但额外增加的工作量却微乎其微

分布式版本控制系统

Distributed Version Control System( DVCS) ,它与传统的集中式版本控制系统(如 SVN)不同

  • 在这类系统中,像 Git、Mercurial、Bazaar 以及 Darcs 等,客户端并不只提取最新版本的文件快照, 而是把代码仓库完整地镜像下来,包括完整的历史记录
  • 这样的话,即使中心服务器崩溃了,只要有任意一个本地副本,就可以完全恢复整个项目历史 -- 因为每一次的克隆操作,实际上都是一次对代码仓库的完整备份

 git

介绍

最初由 Linus Torvalds 为管理 Linux 内核开发而创建

它可以对保存了软件源代码的文件进行版本控制,实际上也适用于任何类型的文件(如文档、图片、配置文件等)

与多个远程仓库协作

在 Git 中,你可以为一个本地仓库配置多个不同的远程仓库,并分别与之进行推送(push)、拉取(pull)、抓取(fetch)等操作

通过这种方式,你可以:

  • 同时与不同的团队协作,比如一个上游项目组和一个自己/你所在小组维护的仓库

  • 为项目设定更灵活的协作策略和工作流,比如:

    • 分层模型(层次结构) : 核心开发者管理主仓库,外部贡献者通过 Fork + Pull Request 的方式参与;

    • 功能分支工作流 : 每个功能一个分支,由不同小组负责

    • Git Flow、GitHub Flow 等流程,适用于不同规模和开发节奏的项目

在传统的集中式版本控制系统(如 SVN)中,开发者一般只能连接到单一的中心仓库,这种灵活的协作模式是很难实现的

对待数据的方式

Git 更像是把数据看作是对小型文件系统的一系列快照

  • 在 Git 中,每当你提交更新或保存项目状态时,它基本上就会对当时的全部文件创建一个快照,并保存这个快照的索引
  • 为了效率,如果文件没有修改,Git 不再重新存储该文件,而是只保留一个链接指向之前存储的文件

Git 像是一个小文件系统提供了许多以此为基础的超强工具

本地执行操作

Git 的一大优势就是:绝大多数操作都可以在本地完成,不依赖网络连接

  • 这样你能立即看到项目历史,而不会受到网络波动的影响 -- 除了需要将修改提交到远端仓库的操作,其他都可以离线完成

如果想查看当前版本与一个月前的版本之间引入的修改:

  • Git 会查找到一个月前的文件做一次本地的差异计算,而不是 由远程服务器处理 / 从远程服务器拉回旧版本文件再来本地处理

保证完整性

Git 在存储每一份数据(包括文件、目录、提交对象等)之前,都会:

  • 计算该数据的 SHA-1 哈希值(40 位的十六进制字符串)作为校验和 -- 基于 Git 中文件的内容或目录结构计算出来

  • 用这个哈希值作为对象id  (Git 数据库中保存的信息都是以文件内容的哈希值来索引,而不是文件名)

  • 然后将该对象存储到 .git/objects 目录中

这个过程确保了两个核心特性:

  • 内容寻址:Git 使用哈希值而非文件名或路径来索引文件 -- 只要内容一样,无论文件名如何变化,其哈希值都不会变,从而避免了重复存储

  • 数据完整性保障:如果文件内容被意外修改,其哈希值会立刻不一致,Git 就能发现异常

只添加数据

Git 绝大多数操作只往 Git 数据库中添加数据,可以把它看做"只追加,不修改"的数据库

  • 每次 git commit 都是创建一个新的提交对象

  • 每个提交引用的对象(文件快照、目录树)也是全新的

  • 历史提交、对象一旦生成,不会被覆盖或修改(除非你手动执行如 rebase, reset --hard 等命令,并且清理了 reflog)

注意,这里指的是已提交的数据 !! 任何你未提交的东西丢失后很可能再也找不到了

  • 对于未提交的更改(比如修改了文件但还没 add / commit):如果你未保存 / 误删 / 执行 git checkout 等命令时,这些更改可能就永远丢失了

  • 对于未暂存的文件(如工作目录中新建的文件但没添加到 Git),一旦被删就没法找回

三种状态

Git 中的文件有三种状态: 已修改,已暂存,已提交

从而让Git 项目拥有三个阶段:工作区,暂存区,Git 目录

工作区
  • 就是你电脑上看到和操作的项目文件夹

  • 这些文件是对项目的某个版本(Git 仓库的压缩数据库中)独立提取出来的内容,也就是 Git 仓库中某个版本的“解压快照”

  • 文件内容可以被你修改,但这些更改还没有被记录到版本历史中

暂存区
  • 一个临时区域,记录哪些更改将包含在下次提交中

  • 实际上是一个隐藏文件,位于 .git/index

  • 你执行 git add 的时候,就是把修改加入这里

Git 目录

是 Git 仓库的核心部分 (从其它计算机克隆仓库时,复制的就是这里的数据),位于 .git 文件夹中

  • Git 用来保存项目的元数据和对象数据库的地方
  • 当你执行 git commit,Git 就把暂存区的内容写入 .git,形成一个不可变的新提交

 基本的git工作流程

相关文章:

git -- 版本控制介绍(分布式系统),git介绍(对待数据的方式,本地执行,保证完整性,只添加数据,git文件/项目的三种状态,基本的工作流程)

目录 版本控制 介绍 分布式版本控制系统 git 介绍 与多个远程仓库协作 对待数据的方式 本地执行操作 保证完整性 只添加数据 三种状态 工作区 暂存区 Git 目录 基本的git工作流程 版本控制 介绍 一种记录一个或多个文件内容变化的系统,它可以让你在未来…...

嵌入式软件OTA升级,有哪几种Flash划分方式?

第一次接触嵌入式软件OTA升级的时候,我整个人也是懵的。Flash划分?什么鬼?不是直接把新程序烧进去就完事了吗? 结果一上手才发现,这玩意没那么简单,尤其是Flash怎么分,如果Flash划分没弄好&…...

游戏引擎学习第226天

引言,计划 我们目前的目标是开始构建“元游戏”结构。所谓元游戏,指的是不直接属于核心玩法本身,但又是游戏体验不可或缺的一部分,比如主菜单、标题画面、存档选择、选项设置、过场动画等。我们正在慢慢将这些系统结构搭建起来。…...

通过python实现bilibili缓存视频转为mp4格式

需要提前下好ffmpeg import os import fnmatch import subprocess Bilibili缓存的视频,*280.m4s结尾的是音频文件,*050.m4s结尾的是视频,删除16进制下前9个0,即为正常音/视频 使用os.walk模块,遍历每一个目录&#xf…...

Windows 图形显示驱动开发-WDDM 1.2功能—无显示器系统支持

一、架构设计与启动流程 1.1无显示器系统启动与全流程 graph TDA[UEFI固件] -->|FADT.VGA_NOT_PRESENT1| B[Windows Boot Manager]B -->|加载winload.efi| C[内核初始化]C -->|检测显示设备| D{存在GPU?}D -->|是| E[加载WDDM驱动]D -->|否| F[激活MSBDD虚拟…...

低代码 Web 组态

低代码配置式 Web 组态是一种用于创建 Web 应用程序界面的技术,它允许用户通过图形化界面和少量的代码或无需编写大量代码来配置和定制 Web 页面的布局、外观和交互功能。 一、特点 1、低代码或无代码开发:大大降低了开发门槛,无需专业的编程…...

解决7穴连接器的信号完整性问题

在汽车发动机的系统设计中,信号传输是不可或缺的。在信号传输中起着重要作用的一个关键组件是 7 穴连接器,它提供许多重要功能。 但是,这些连接器可能会遇到一些制造商需要解决的问题,知道如何解决 7 腔连接器中的信号完整性问题…...

GDScript快速入门(适合有其它编程语言基础)

GDScript快速入门(适合有其它编程语言基础) 从零开始学 GDScript Godot 是一款开源、跨平台的游戏引擎,因其轻量、易用和强大的功能而受到广大开发者的喜爱。在 Godot 中,GDScript 是其专为游戏开发设计的脚本语言,具…...

WEB安全--蓝队日志--RCE数据包分析

一、分析数据包内容 攻击者通过URL请求POST传参的方式试图绕过IPS测试RCE漏洞的利用 URL请求中的内容进行urlcode解码后是这样的: http://资产IP/hello.world?-d allow_url_include1 -d auto_prepend_filephp://input 1. -d allow_url_include1: 使…...

springboot项目添加定时任务,用sftp推送zip包到目标服务器

用sftp推送zip包到目标服务器 任务类里面,主要功能是,定时采集三张表的数据,并把数据转换成csv,三份csv压缩成一个加密的zip包,通过sftp推送到指定的目录下 配置类 Data Configuration ConfigurationProperties(pre…...

Mobaxterm 突破 14个 session 限制

mobaxterm 可以说非常好用,但是免费版对会话有限制,对于有很多虚拟机会话需要存储的我来说确实太少了。 当Xterm会话数量到14个时,发现新增的会话没有保存下来,在左侧菜单无法新增保存会话session。 超过限制时,提示…...

体系结构论文(七十一):Quantifying the Impact of Data Encoding on DNN Fault Tolerance

Quantifying the Impact of Data Encoding on DNN Fault Tolerance 研究动机 深度神经网络(DNN)在硬件运行时可能遇到位翻转(bit-flip)错误,特别是在能效和面积敏感的平台上(如边缘设备、移动端&#xff0…...

学习笔记十一——零基础搞懂 Rust 函数式编程

🧠 零基础搞懂 Rust 函数式编程:到底什么是 “函数式”? Rust 是一门多范式语言,既可以像 C/Java 那样写“命令式代码”,也支持“函数式编程”。但很多刚入门的小伙伴可能会有这些疑问: 函数不就是函数吗&…...

Spark-SQL2

利用IDEA开发Spark-SQL 自定义函数 UDF: UDAF(自定义聚合函数) 强类型的 Dataset 和弱类型的 DataFrame 都提供了相关的聚合函数, 如 count(),countDistinct(),avg(),max(),min()。…...

python实战案例:玩具销售数据分析

原创 IT小本本 IT小本本 2025年04月12日 22:45 北京 本文将通过一个玩具销售数据的分析案例,展示如何利用 Python 和数据可视化工具从原始数据中提取有价值的商业洞察。将从数据加载、预处理到可视化分析,逐步揭示玩具销售的规律和趋势。 数据准备与加…...

模拟浏览器指纹:生成与定制特定属性

在现代网络环境中,浏览器指纹是一种强大的标识技术,用于区分不同的浏览器实例。通过收集浏览器的各种属性(如用户代理、Canvas 指纹、WebGL 特性等),可以生成一个独特的指纹,用于跟踪用户行为或防止欺诈。本…...

vue+vite 减缓首屏加载压力和性能优化

vuevite 减缓首屏加载压力和性能优化 1、预加载项目必需的组件2、模块加载优化3、HMR 热更新优化4 、环境配置优化5、代码模式优化6、高级优化技巧7、架构级优化打包压缩配置 在vuevite构建的工程里面,性能优化分为开发环境和打包后的生产环境,作为开发首…...

狂神SQL学习笔记十三:Delete 和 Truncate 详解

1、删除 保留表的结构不变,清空表的数据 truncate重新设置 自增列 计数器会归零,如果用delete删除,则自增不会变,重新插入数据时自增会从原来的地方开始...

封装实用的时间选择器组件

<template><!-- 使用该时间选择器组件&#xff0c;重置搜索表单的时候&#xff0c;注意得使用async await让重置表单操作完成后再发起请求 --><div class"dateTimePickerSelectWrap"><el-date-pickerv-model"arr":type"dateType…...

关于Blade框架对数字类型的null值转为-1问题

关于Blade框架对数字类型的null值转为-1问题 问题&#xff1a;最近项目遇到了一个问题&#xff0c;SpringBoot项目后端Long类型的数据&#xff0c;如果是NULL的话&#xff0c;返回给前端的时候是-1。如下图&#xff1a; 分析 是由于使用了 blade 框架&#xff0c;项目启动的…...

如何安全地管理固定功能设备?

什么是固定功能设备&#xff1f; 固定功能设备是指具有特定、单一或有限功能的设备&#xff0c;其功能在设计和制造时就被固定下来&#xff0c;通常难以进行大规模的功能扩展或修改。固定功能设备只需要运行特定的应用程序。自动取款机、销售商家用机器、支付站点以及其他专门…...

AttributeError: ‘NoneType‘ object has no attribute ‘pydev_do_not_trace‘

目录 问题描述1. **IDE缓存损坏**(此办法帮我解决问题)2. **PyCharm版本过旧**3. **Python解释器配置问题**4. **第三方库或插件冲突**5. **重置调试配置**其他建议问题原因分析 问题描述 print(ok) Traceback (most recent call last):File "D:\pycharm\PyCharm Communi…...

协享云图分析--3用户模块

用户表 -- 用户表 create table if not exists user (id bigint auto_increment comment id primary key,userAccount varchar(256) not null comment 账号,userPassword varchar(512) not null comment 密码…...

visual studio 如何在 release 模式下调试

在 Visual Studio 中&#xff0c;在 Release 模式下进行调试, 以下是具体步骤&#xff1a; 一、修改项目属性&#xff1a; 右键点击解决方案资源管理器中的项目&#xff0c;选择“属性”。 在“生成”选项卡中&#xff0c;找到“定义 DEBUG 常量”和“定义 TRACE 常量”&…...

课堂总结。

第三章第六节 Spark-SQL核心编程&#xff08;五&#xff09;自定义函数&#xff1a;UDF&#xff1a;val sparkConf new SparkConf().setMaster("local[*]").setAppName("SQLDemo")//创建SparkSession对象val spark :SparkSession SparkSession.builder()…...

JDBC 初认识、速了解

目录 一. JDBC的简介 1. 数据的持久化 2. 什么是JDBC 二. JDBC中常用的类和接口 1. Driver 接口 2. DriverManager 类 3. Connection 接口 4. Statement 接口 5. PreparedStatement接口 6. ResultSet 接口 三. 总结 前言 从现在开始就来讲解JDBC的相关知识了 本文的…...

双指针算法

引入 双指针顾名思义&#xff0c;就是同时使用两个指针&#xff0c;在序列、链表结构上指向的是位置&#xff0c;在树、图结构中指向的是节点&#xff0c;通过或同向移动&#xff0c;或相向移动来维护、统计信息。 ——OI Wiki 接下来我们来看双指针的几个具体使用方法。 板子…...

关于TD算法的笔记【时间差分】

1. TD算法逻辑&#xff1a;TD算法即时间差分算法&#xff0c;结合了蒙特卡洛方法和动态规划思想&#xff0c;通过当前估计值和下一个时间步观测值更新状态价值估计&#xff0c;无需完整episode或环境完整信息。 2. 下一时刻估计值计算&#xff1a;下一时刻估计值为 r_{t 1}\g…...

计算斐波那契数列

1.对于斐波那契数列的理解&#xff1a; (1)常规 该数列由兔子繁衍的想法产生&#xff0c;故又“兔子数列” 其数值为&#xff1a;1、1、2、3、5、8、13、21、34 从数学定义上走&#xff1a;F(0)1&#xff0c;F(1)1, F(n)F(n - 1)F(n - 2)&#xff08;n ≥ 2&#xff0c;n ∈…...

Oracle REGEXP_SUBSTR

在 Oracle 数据库中&#xff0c;REGEXP_SUBSTR 是一个基于正则表达式的字符串处理函数&#xff0c;用于从目标字符串中提取符合特定模式的子串。它比传统的 SUBSTR 函数更灵活&#xff0c;适用于复杂的模式匹配需求。以下是其核心原理、参数解析及实际案例详解&#xff1a; 一…...

无人机自主导航与路径规划技术要点!

一、自主导航与路径规划技术要点 1. 传感器融合 GPS/北斗定位&#xff1a;提供全局定位&#xff0c;但在室内或遮挡环境下易失效。 惯性测量单元&#xff08;IMU&#xff09;**&#xff1a;通过加速度计和陀螺仪实时追踪姿态&#xff0c;弥补GPS信号丢失时的定位空缺。 …...

DDS波形发生器仿真及技术原理

1. 引言 在现代数字信号处理、电路设计以及通信系统中&#xff0c;直接数字频率合成&#xff08;DDS&#xff09;技术因其高速、精细的频率分辨率以及连续相位输出等优点而得到广泛应用。本文主要探讨在DE2-115开发板平台上基于DDS技术实现波形发生器的设计与实践。通过该设计…...

Java使用ANTLR4解析IDL文件

文章目录 前言解析IDL文件准备两个IDL文件准备一个IDL Grammar文件maven配置生成Lexer Parser Listener Visitor代码新建实体类IDL解析遍历器单元测试 参考 前言 接着上篇&#xff1a;Java使用ANTLR4对Lua脚本语法校验&#xff0c;介绍了什么是ANTLR&#xff1f;/ 举了一个hel…...

04-Seata 深度解析:从分布式事务原理到 Seata 实战落地

Seata 深度解析&#xff1a;从分布式事务原理到 Seata 实战落地 一、分布式事务核心理论与挑战 1.1 分布式事务的本质难题 在微服务架构中&#xff0c;一次业务操作可能涉及多个服务的数据库操作&#xff0c;传统单体事务&#xff08;ACID&#xff09;无法跨越服务边界&…...

2025企业增长新引擎:AI Agent驱动人效跃迁|白皮书2.0发布

2025年伊始&#xff0c;一款名为DeepSeek-R1的国产AI大模型以其高性能、低成本等核心优势成功霸榜热搜&#xff0c;在全国乃至全球掀起一场以AI为核心的技术革新与管理变革。 面对这样极具颠覆性的革新命题&#xff0c;易路人力资源科技王天扬先生自2022年起就率团队持续专注于…...

IJCV-2025 | 深圳大学记忆增强的具身导航!ESceme:基于情景记忆的视觉语言导航

作者&#xff1a;Qi Zheng 1 , 2 ^{1,2} 1,2, Daqing Liu 3 ^{3} 3, Chaoyue Wang 3 ^{3} 3, Jing Zhang 2 ^{2} 2, Dadong Wang 4 ^{4} 4, Dacheng Tao 2 ^{2} 2单位&#xff1a; 1 ^{1} 1深圳大学电子与信息工程学院&#xff0c; 2 ^{2} 2悉尼大学计算机科学学院&#xff0c;…...

[第十六届蓝桥杯 JavaB 组] 真题 + 经验分享

A&#xff1a;逃离高塔(AC) 这题就是简单的签到题&#xff0c;按照题意枚举即可。需要注意的是不要忘记用long&#xff0c;用int的话会爆。 &#x1f4d6; 代码示例&#xff1a; import java.io.*; import java.util.*; public class Main {public static PrintWriter pr ne…...

《分布式软总线:网络抖动下的数据传输“定海神针”》

在当下&#xff0c;智能设备之间的互联互通已成为生活与工作的刚需。分布式软总线作为实现这一愿景的关键技术&#xff0c;正日益凸显其重要性。然而&#xff0c;网络环境的复杂性&#xff0c;尤其是网络抖动频繁的情况&#xff0c;给分布式软总线的数据传输带来了严峻挑战。如…...

C++函数

函数 为什么要使用函数 已经有main函数&#xff0c;为什么还要自定义函数&#xff1f;&#xff1a;“避免重复制造轮子”&#xff0c;提高开发效率 函数的定义 函数的设计方法&#xff1a;先确定函数的功能、确定函数的参数、是否需要参数&#xff0c;参数的个数&#xff0c…...

FreeRTOS菜鸟入门(五)·空闲任务与阻塞延时的实现

目录 1. 实现空闲任务 1.1 定义空闲任务的栈 1.2 定义空闲任务的任务控制块 1.3 创建空闲任务 2. 实现阻塞延时 2.1 vTaskDelay()函数 2.2 修改 vTaskSwitchContext()函数 3. SysTick 中断服务函数 4. SysTick 初始化函数 通过之前我们了解知道&#xff0c;任…...

PCIe 学习笔记(一)

系列文章目录 【PCIe】链路测试&#xff0c;数字工程师也要会看高速信号眼图&#xff01; 【PCIe】链路训练状态机(LTSSM) - PCIe链路建立过程概述 【PCIe】PCIe设备的BDF与系统枚举过程 文章目录 系列文章目录PCIe LTSSM**1. 链路训练状态&#xff08;Training States&#…...

【正点原子STM32MP257连载】第四章 ATK-DLMP257B功能测试——LED、按键测试

1&#xff09;实验平台&#xff1a;正点原子ATK-DLMP257B开发板 2&#xff09;浏览产品&#xff1a;https://www.alientek.com/Product_Details/135.html 3&#xff09;全套实验源码手册视频下载&#xff1a;正点原子资料下载中心 文章目录 第四章 ATK-DLMP257B功能测试4.1 LED…...

深度为16,位宽8bit的单端口SRAM——学习记录

链接&#xff1a; 【Verilog HDL 训练】第 13 天&#xff08;存储器、SRAM&#xff09;-云社区-华为云 module sram #(parameter ADDR_BITS4)(input clk,input [ 7:0] addr,input [ 7:0] din,input ce,input we,output reg [ 7:0] dout);localparam MEM_DEPTH 1<<ADDR_…...

面向对象编程

在面向对象编程中&#xff0c;除了通过创建类的实例来访问其属性和方法外&#xff0c;还可以通过在一个类里创建另一个类的属性&#xff08;本质上也是持有另一个类的实例引用&#xff09;的方式来访问该类的属性和方法。下面为你详细解释这两种方式&#xff1a; 1. 通过创建实…...

远程登录一个Linux系统,如何用命令快速知道该系统属于Linux的哪个发行版,以及该服务器的各种配置参数,运行状态?

远程登录一个Linux系统&#xff0c;如何用命令快速知道该系统属于Linux的哪个发行版&#xff0c;以及该服务器的各种配置参数&#xff0c;运行状态&#xff1f; 查看Linux发行版信息 查看发行版名称和版本&#xff1a; cat /etc/*-release或 lsb_release -a查看内核版本&#…...

简单socket通信,回显 服务器程序与客户端程序之间的通信。

Socket 通信编程是一种基于网络的通信方式&#xff0c;允许不同主机上的程序通过网络进行数据交换。 实现结构try catch&#xff1a; 前情了解&#xff1a; 1.如何创建服务器端 定义ServerSocket套接字&#xff0c;需要等待客户端连接&#xff0c;阻塞&#xff0c;直到接入连接…...

C# 基类型和派生类型之间的转型

1.什么是基类型和派生类 基类型&#xff1a;父类&#xff0c;所有子类都继承自它。 派生类型&#xff1a;子类&#xff0c;继承了父类的属性和方法&#xff0c;还可以添加自己的新功能。 例子&#xff1a; class Animal { }//基类型 class Dog : Animal { }//派生类型 这…...

深度学习--激活函数

激活函数通过计算加权和并加上偏置来确定神经元是否应该倍激活&#xff0c;它们将输入信号转换为输出的可微运算。大多数激活函数都是非线性的&#xff0c;由于激活函数是深度学习的基础&#xff0c;下面简要介绍一些常见的激活函数。 1 RelU函数 最受欢迎的激活函数是修正线性…...

MySQL 缓存机制全解析:从磁盘 I/O 到性能优化

MySQL 缓存机制全解析&#xff1a;从磁盘 I/O 到性能优化 MySQL 的缓存机制是提升数据库性能的关键部分&#xff0c;它通过多级缓存减少磁盘 I/O 和计算开销&#xff0c;从而提高查询和写入的效率。 1. 为什么需要缓存&#xff1f; 数据库的性能瓶颈通常集中在磁盘 I/O 上。…...

【项目管理】第17章 项目干系人管理-- 知识点整理

项目管理-相关文档,希望互相学习,共同进步 风123456789~-CSDN博客 (一)知识总览 项目管理知识域 知识点: (项目管理概论、立项管理、十大知识域、配置与变更管理、绩效域) 对应:第6章-第19章 第6章 项目管理概论 4分第13章 项目资源管理 3-4分第7章 项目…...