PHP培训-高端面授PHP培训机构
云和教育:云和数据集团高端IT职业教育品牌
  • 华为
    授权培训中心
  • 腾讯云
    一级认证培训中心
  • 百度营销大学
    豫陕深授权运营中心
  • Oracle甲骨文
    OAEP中心
  • Microsoft Azure
    微软云合作伙伴
  • Unity公司
    战略合作伙伴
  • 普华基础软件
    战略合作伙伴
  • 新开普(股票代码300248)
    旗下丹诚开普投资
  • 中国互联网百强企业锐之旗
    旗下锐旗资本投资

Git是什么?这6个基础概念你需要了解

  • 发布时间:
    2022-05-21
  • 版权所有:
    云和教育
  • 分享:

什么是 Git?

Git 是一个开源的分布式版本控制系统,是目前世界上最先进、最流行的版本控制系统。可以快速高效地处理从很小到非常大的项目版本管理。特点:项目越大越复杂,协同开发者越多,越能体现出 Git 的高性能和高可用性。

Git 的特性

Git 之所以快速和高效,主要依赖于它的两个特性:直接记录快照,而非差异比较;近乎所有操作都是本地执行。

1.SVN 的差异比较

传统的版本控制系统(例如 SVN)是基于差异的版本控制,它们存储的是一组基本文件和每个文件随时间逐步累积的差异。

SVN 的差异比较

 

好处:节省磁盘空间,缺点:耗时、效率低。在每次切换版本的时候,都需要在基本文件的基础上,应用每个差异,从而生成目标版本对应的文件。

2.Git 的记录快照

Git 快照是在原有文件版本的基础上重新生成一份新的文件,类似于备份。为了效率,如果文件没有修改,Git不再重新存储该文件,而是只保留一个链接指向之前存储的文件。

Git 的记录快照

缺点:占用磁盘空间较大

优点:版本切换时非常快,因为每个版本都是完整的文件快照,切换版本时直接恢复目标版本的快照即可。

特点:空间换时间

3.近乎所有操作都是本地执行

在Git 中的绝大多数操作都只需要访问本地文件和资源,一般不需要来自网络上其它计算机的信息。基于这一特点,Git在断网后依旧可以在本地对项目进行版本管理,只需联网后,把本地修改的记录同步到云端服务器即可。

4.Git 中的三个区域

使用Git 管理的项目,拥有三个区域,分别是工作区、暂存区、Git 仓库。如果把这些区域比作现实中纸质文件的人工处理和收纳管理,三个区域分别负责的任务是:

工作区:负责处理工作的区域。

暂存区:已完成的工作的临时存放区域,等待被提交。

Git 仓库:最终的存放区域。

5.Git 中的三种状态

已修改:表示修改了文件,但还没将修改的结果放到暂存区

已暂存:表示对已修改文件的当前版本做了标记,使之包含 在下次提交的列表中;

已提交:表示文件已经安全地保存 在本地的Git 仓库中。

注意:工作区的文件被修改了,但还没有放到暂存区,就是已修改状态。 如果文件已修改并放入暂存区,就属于已暂存状态。 如果Git 仓库中保存着特定版本的文件,就属于已提交状态。

6.基本的Git 工作流程

基本的Git 工作流程

基本的Git 工作流程如下:

①在工作区中修改文件

②将你想要下次提交的更改进行暂存

③提交更新,找到暂存区的文件,将快照永久性存储到Git 仓库.