zoukankan      html  css  js  c++  java
  • Git基础

      Git是神Linus Torvalds使用c开发的一个版本控制系统,该系统的开发基于以下目标:

    • 速度
    • 简单的设计
    • 对非线性开发模式的强力支持(允许成千上万个并行开发的分支)
    • 完全分布式
    • 有能力高效管理类似Linux内核一样的超大规模项目(速度和数据量)

      那么,Git究竟是怎样一个系统呢?若你理解Git的思想和基本工作原理,用起来会知其所以然、游刃有余。尽管操作起来的命令形式与其他版本控制系统非常相似,但Git在保存和对待各种信息的时候与其他版本控制系统有很大差异,理解这些差异将便于高效使用Git。

    1. 直接记录快照,而非差异比较

      Git 和其它版本控制系统(包括 Subversion 和近似工具)的主要差别在于 Git 对待数据的方法。 理念上看,其他大部分系统以文件变更列表的方式存储信息,这类系统(CVS、Subversion、Perforce、Bazaar等)将它们保存的信息看做一组基本文件和每个文件随时间逐步累积的差异。

      Git 则把数据看作是对小型文件系统的一组快照。 每次提交更新,或在Git中保存项目状态时,它主要对当时的全部文件制作一个快照并保存这个快照的索引。如果没有修改文件,Git不再重新存储文件,而只保留一个链接指向之前存储的文件。Git对待数据更像是一个快照流。

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

      在 Git 中的绝大多数操作都只需要访问本地文件和资源,一般不需要来自网络上其它计算机的信息。你在本地磁盘上就有项目的完整历史,所以大部分操作看起来瞬间完成。这样你可以再离线或没有VPN时,几乎可以进行任何操作。

    3. Git保证完整性

      在 Git 中的Git 中所有数据在存储前都计算校验和,然后以校验和来引用。 这意味着不可能在 Git 不知情时更改任何文件内容或目录内容。 这个功能建构在 Git 底层,是构成 Git 哲学不可或缺的部分。 若你在传送过程中丢失信息或损坏文件,Git 就能发现。

      Git 用以计算校验和的机制叫做 SHA-1 散列(hash,哈希)。 这是一个由 40 个十六进制字符(0-9 和 a-f)组成字符串,基于 Git 中文件的内容或目录结构计算出来。 SHA-1 哈希看起来是这样:

      24b9da6552252987aa493b52f8696cd6d3b00373 

      Git 中使用这种哈希值的情况很多,你将经常看到这种哈希值。 实际上,Git 数据库中保存的信息都是以文件内容的哈希值来索引,而不是文件名。 

    4. Git一般只添加数据

      在 Git 中,执行的 Git 操作几乎只往 Git 数据库中增加数据。 很难让 Git 执行任何不可逆操作,或者让它以任何方式清除数据。 同别的 VCS 一样,未提交更新时有可能丢失或弄乱修改的内容;但是一旦你提交快照到 Git 中,就难以再丢失数据,特别是如果你定期的推送数据库到其它仓库的话。更深度探讨 Git 如何保存数据及恢复丢失数据的话题,请参考撤消操作。 

    5. 三种状态  

      Git 有三种状态,你的文件可能处于其中之一:已提交(committed)、已修改(modified)和已暂存(staged)已提交表示数据已经安全的保存在本地数据库中。 已修改表示修改了文件,但还没保存到数据库中。 已暂存表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。

      由此引入 Git 项目的三个工作区域的概念:Git 仓库、工作目录以及暂存区域


      Git 仓库目录是 Git 用来保存项目的元数据和对象数据库的地方。 这是 Git 中最重要的部分,从其它计算机克隆 仓库时,拷贝的就是这里的数据。工作目录是对项目的某个版本独立提取出来的内容。 这些从 Git 仓库的压缩数据库中提取出来的文件,放在磁盘上供你使用或修改。

      暂存区域是一个文件,保存了下次将提交的文件列表信息,一般在 Git 仓库目录中,有时也被称作`‘索引’'

      基本的 Git 工作流程如下:

      1. 在工作目录中修改文件。

      2. 暂存文件,将文件的快照放入暂存区域。

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

      如果 Git 目录中保存着的特定版本文件,就属于已提交状态。 如果作了修改并已放入暂存区域,就属于已暂存状态。 如果自上次取出后,作了修改但还没有放到暂存区域,就是已修改状态。 后续你会进一步了解这些状态的细节,并学会如何根据文件状态实施后续操作,以及怎样跳过暂存直接提交。

    6. 命令行  

      Git 有多种使用方式,你可以使用原生的命令行模式,也可以使用 GUI 模式,这些 GUI 软件也能提供多种功能。但只有在命令行模式下你才能执行 Git 的 所有 命令,而大多数的 GUI 软件只实现了 Git 所有功能的一个子集以降低操作难度。 如果你学会了在命令行下如何操作,那么你在操作 GUI 软件时应该也不会遇到什么困难,但是,反之则不成立。 

  • 相关阅读:
    ALOS卫星概况
    如何安装和配置jdk6u18windowsi586.exe
    请问是否可以直接发布切片好的服务 arcgis serever
    eclipse and myeclipse
    GISer还有机会屌丝逆袭吗?
    ArcGIS中加载百度地图
    细说委托
    白话地图投影之Proj.4地图投影库简介
    让OpenLayers添加百度地图(未完版)
    白话地图投影之墨卡托投影
  • 原文地址:https://www.cnblogs.com/yanqingyang/p/9514964.html
Copyright © 2011-2022 走看看