git简述

作者: harvey_dong | 来源:发表于2017-06-03 10:07 被阅读9次

git简介

git是一款开源的分布式版本管理工具,git的诞生也是相当传奇的,由Linux之父-Linus Benedict Torvalds开发而来,当初Linus Benedict Torvalds仅仅是为了辅助Linux内核的开发才一并开发了这个至今为止世界上最快的、最简单的版本管理工具。

git原理

首先要明确一点: git中一切都是文件(Unix系统理念)

git是分布式的版本管理工具,每一个工作者本地都有一个中心仓库,同时在远程分支是还有一个中心仓库,平时开发时的操作(add,commit)都是对本地分支进行操作。当开发完一个功能或解决完bug后就需要把本地的修改同步到远程分支中(push ,pull)。这样每个工作者就可以在本地同时开发,只需在同步时做好合并工作就可以。可以很大的提高工作效率,而且出错也很少。

git分布式图

Git 的工作就是创建和保存你的项目的快照及与之后的快照进行对比。

git一共分为三个部分工作区(workingCopy)、暂存区(stage)、中心仓库(master)

git内部结构

当平时修改代码时改动的是工作区,使用git add命令时就会把工作区的修改保存在暂存区,使用git commit 命令会把暂存区的修改提交到本地仓库。使用push会将本地仓库的提交同步到远程仓库。所以流程是workingCopy  ------->stage ------>master ------>remote。

注意:git stash 命令是新开辟一个栈来保存工作区的改动,不会添加到暂存区。

git是以指针为基础的,存储在 git 中的所有东西都包含在一个文件中。当你提交的时候,git 会创建一个包含提交消息和相关数据的文件(名称、邮件、日期/时间、上一次提交等等),并将其链接到一个树形文件。树形文件包含一个对象列表或者其它树。对象或二进制大数据对象(BLOB)是提交的真正内容(虽然文件名没有存储在对象中,但会存储在树中)。所有这些文件都以对象的 SHA-1 哈希为文件名进行存储。

 分支和标签只是一些文件,这些文件包含(基本上)一个指向提交的 SHA-1 哈希值。使用这些引用在灵活性和速度上均有大幅提升,创建一个新的分支就和创建一个文件一样简单,只是这个文件带有分支名称和一个包含指向提交(你从这个提交建立分支)的SHA-1哈希值。

相关文章

  • GIT 简述

    一、版本控制用文档记录每个模块的改动,存储、追踪修改历史。方便恢复版本以及版本查看。 二、版本控制软件- SVN ...

  • git简述

    git简介 git是一款开源的分布式版本管理工具,git的诞生也是相当传奇的,由Linux之父-Linus Ben...

  • 实习第一天,上司让我学习一下Git Flow

    简述Git Flow 首先,Git Flow并不是Git的替代品,Git Flow只是把标准的Git命令用脚本组合...

  • 前端面试2021-004

    1、简述git中常见的操作命令以及它们的含义 2、简述git和svn的区别,如何在项目中选择使用什么版本工具呢? ...

  • git 命令简述

    创建版本库初始化一个Git仓库,使用git init命令。添加文件到Git仓库,分两步: 第一步,使用命令git ...

  • Git 操作简述

    1. git 回退版本 git log 查看某个分支的历史版本,版本号类似于:7d553c3b80ca77a48d...

  • Git使用简述

    第一阶段[无分支操作]    第二阶段[创建分支进行操作] 遇到问题:代码出现bug需要暂停现有工作,进入fix ...

  • Git实现简述

    今天再次复习了git的相关内容,我觉得其中有部分内容值得记录,关于其做版本管理的实现方式。 首先git创建成功后会...

  • 前端面试2021-001

    1. 简述git第一次使用时,需要进行那些配置? git全局配置,初始化开发人员信息 git config --g...

  • 前端面试2021-010

    1、简述git常见的操作命令和含义,描述一个你在操作git时让自己印象较为深刻的问题以及解决过程 git conf...

网友评论

    本文标题:git简述

    本文链接:https://www.haomeiwen.com/subject/bvypfxtx.html