zoukankan      html  css  js  c++  java
  • Git 学习(二)Git 基础

    Git 基础

    Git 在保存和对待各种信息的时候与其它版本控制系统如 SVN 等等有很大差异,尽管操作起来的命令形式非常相近,理解这些差异将有助于防止你使用中的困惑。

    Git 记录的是什么?

    如果有使用 SVN 等其他版本控制系统的经验,应该知道它们的工作原理是记录每一次的变动。将它们保存的信息看作是一组基本文件和每个文件随时间逐步累积的差异。
    在这里插入图片描述

    而 Git 却决定剑走偏锋,以一种看似“异端”的方式来处理版本迭代。Git 不按照以上方式对待或保存数据。 反之,Git 更像是把数据看作是对小型文件系统的一组快照。 每次你提交更新,或在 Git 中保存项目状态时,它主要对当时的全部文件制作一个快照并保存这个快照的索引。
    在这里插入图片描述
    如上,如果每个版本中有文件发生变动,Git 会将整个文件复制并保存起来。这种设计看似会多消耗更多的空间,但在分支管理时却是带来了很多的益处和便利。

    三种状态

    Git 有三种状态,你的文件可能处于其中之一

    1. 已提交(committed):已提交表示数据已经安全的保存在本地数据库中。
    2. 已修改(modified):已修改表示修改了文件,但还没保存到数据库中。
    3. 已暂存(staged):已暂存表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。

    由此引入 Git 项目的三个工作区域的概念:工作区域、暂存区域和 Git 仓库
    在这里插入图片描述

    1. 工作区域(Working Directory)就是你平时存放项目代码的地方。
    2. 暂存区域(Stage)用于临时存放你的改动,事实上它只是一个文件,保存即将提交的文件列表信息。
    3. Git 仓库(Repository)就是安全存放数据的位置,这里边有你提交的所有版本的数据。其中,HEAD 指向最新放入仓库的版本(确切的说,应该是 Git 仓库中 HEAD 指向的版本)。

    基本的 Git 工作流程如下:

    1. 在工作目录中修改文件。
    2. 暂存文件,将文件的快照放入暂存区域。
    3. 提交更新,找到暂存区域的文件,将快照永久性存储到 Git 仓库目录。

    因此,Git 管理的文件的三种状态一次依次对应上边的每一个流程。记住这三个工作区域,因为后边教的所有 Git 操作基本上都是在这三个工作区域之间搞来搞去!

  • 相关阅读:
    BZOJ3779: 重组病毒
    BZOJ3112 [ZJOI2013]防守战线
    BZOJ4011 [HNOI2015]落忆枫音
    BZOJ2726 [SDOI2012]任务安排
    BZOJ1492 [NOI2007]货币兑换
    BZOJ1597 [USACO2008]土地购买
    BZOJ3611 [HEOI2014]大工程
    BZOJ3991 [SDOI2015]寻宝游戏
    BZOJ3675 [APIO2014]序列分割
    BZOJ1010 [HNOI2008]玩具装箱
  • 原文地址:https://www.cnblogs.com/liufeichn/p/11961625.html
Copyright © 2011-2022 走看看