1.git为分布式的版本控制系统,有远程仓库和本地仓库,远程仓库和本地仓库之间建立关联关系后,可将本地仓库的更新push(相当于是内容同步)到远程仓库进行保存,远程仓库的作用相当于一个最终代码备份的地方;

2.git之所以称作分布式的版本控制系统,就是因为git本地仓库的作用,无需连接远程仓库,开发人员即可直接使用本地仓库完成代码在本地仓库中的提交和版本控制,就相当于在本地有一个完全独立的属于自己的版本控制系统。最后只需要在合适的时候,将本地仓库的相应分支推送到远程仓库进行更新同步即可;

3.创建本地仓库的主要方式:

  1).从远程仓库克隆,使用git clone 命令将远程仓库克隆到本地的一个文件夹后,即会建立一个和远程仓库有关联的本地仓库,并且默认也会在本地仓库中创建master分支,也会将本地的master分支和远程仓库的master分支进行关联(即建立追踪关系);

  2)直接从本地使用git init命令进行创建,即在一个文件夹下使用git init命令后,在该文件夹下将生成一个名为.git的隐藏文件夹(该文件夹为git的版本库),有.git文件夹的目录及其子目录中的所有文件将会被git进行跟踪管理(git能够跟踪管理的是文本文件的修改,删除),存在.git隐藏文件夹的文件夹即为本地仓库;

    本地仓库建好后,使用 git remote add origin  git@gitlab.com:XXX/XXX.git 命令添加一个远程仓库(即和一个远程仓库建立关联关系后将代码push到远程),如果该远程仓库已经存在,则直接建立联系,如果不存在则会在远程创建一个名字为XXX.git的仓库(添加远程仓库,最后git push后就会创建);

4.git仓库的结构

  由工作区和版本库构成,如下图:

工作区:就是电脑里能看到的目录,比如上图中的除了.git文件夹之外的所有文件夹及其子目录就属于工作区,这里是开发中存储并修改文件的区域,只要工作区的内容一更新,git就能跟踪到变化。工作区的内容和版本库中的内容是保持同步的,就是通过比较工作区和版本库中的内容来确定工作区中是否有更改内容

版本库:工作区中有一个隐藏目录.git,就是Git的版本库,这个目录是Git来跟踪管理版本的,版本库里存放了已提交的版本,另外其中比较重要的还有state(或者叫index)的暂存区, 还有Git为我们自动创建的第一个分支master(我们在仓库中的工作空间,可以看做是仓库的最小单元,我们所有的操作都是在一个分支上进行的,分支和分支之间是独立的),以及指向master的一个指针叫HEAD。

暂存区(stage):在commit之前暂时存放修改文件的地方。所有需要commit的文件首先都需要加入到暂存区中后才能进行commit.

将文件提交到版本库中需分两步执行:

第一步:使用git add命令将工作区中的修改了的文件添加到暂存区;

第二步:使用git commit命令将暂存区的所有修改文件提交到当前分支(注意提交是提交到某个分支),没有在处在暂存区的修改将不会被提交;

5.git是通过每次commit作为节点进行版本记录。每次commit后都会记录commit时的时间,还会生成一个commit id ,通过id可进行版本的还原。

6.分支:是仓库中的构成单元,仓库中会存在很多分支,我们都是在某一个分支上进行工作(我们工作时都是先进入到仓库的某一个分支后,然后在该分支上执行各种git命令),分支可以理解为不同的工作区(或工作场景),每个分支都对应有自己的工作区文件内容, 切换分支后,工作区中的文件内容也会对应做改变。在某个分支下新建一个分支其实就是基于该分支的当前节点拷贝了一个新的工作区。  有了分支的概念后,我们所使用的git commit, git pull,git push 等命令都是相对于分支来讲的。

7.git 的几个命令的理解:

 git commit     将所有暂存区中的修改内容提交到当前分支版本库保存

git push 远程主机名  本地分支 :远程分支     将本地仓库中的某一个分支内容推送到一个远程分支下,如 git push origin test : dev,将本地的test分支内容推送到远程的dev分支下,test分支的内容作为dev分支下的内容。如果远程分支dev不存在,将会在远程创建一个名为dev的分支。一般本地分支名称和远程分支名称是相同的,所以这里一般可以不写远程分支名称,即直接写成:git push origin test ,会将test分支的更新内容自动推送到远程的test分支下,如果不存在,则在远程会创建一个名为 test的分支。如果本地和远程分支的名称不一样,则需要按照前面的写法进行分支名称的对应。git push时是将commit后的更改内容push到远程分支中,并不是所有。git push命令随时可以使用,不受是否存在未commit 或 未add的文件影响。

git pull 远程主机名   远程分支:本地分支     将远程的某一分支内容获取到后和本地指定的分支进行合并。如 git pull origin test:dev,获取远程的test分支和本地的dev分支进行合并,如果本地的指定的dev分支不存在,则默认会创建一个dev分支。

上面 “本地分支 :远程分支 ”这种就是在push或pull时建立了本地分支和远程分支之间的对应关系。也就是说我们要push或pull的时候,要搞清楚从哪里来,到哪里去。我们在初学时要建立本地远程库和库之间对应,分支和分支对应这样的概念。这样使用push 或 pull 之类的命令时就感觉很清晰。

以上只是个人初学git时的一些浅薄的理解,是对自己学习过程的一个记录。详细可参考以下大神的一些总结文章:

Git使用总结(包含Git Bash和Git GUI的使用)

Git Bash使用详细教程

关于git使用的几点理解的更多相关文章

  1. 【原创】关于Git暂存区的理解

    关于Git暂存区的理解      暂存区可以说是Git的三大重要的区域之一,另外两个分别是工作目录和Git仓库,所以说对暂存区的深入理解可以帮助我们理解很多Git命令背后隐藏的工作原理.今天,本文将以 ...

  2. 关于git提交的自己的理解

    包子不才,对于码云上的git的使用,自己的理解是 这个命令用于查看,哪些文件被修改了,以及修改了哪些地方, 这个命令用于增加你新添的文件,如果该文件已经存在,那么这一步则可以省略,随后就是commit ...

  3. git 4种对象的理解

    git中有四种基本对象类型,可以说Git的所有操作都是通过这四种对象完成的.下图是<Git版本控制管理>中文第二版的原话,顺便吐槽一下,这本书真的翻译的一般.. 下面说下我的理解吧,首先b ...

  4. 【Git 学习三】深入理解git reset 命令

    重置命令(git reset)是Git 最常用的命令之一,也是最危险最容易误用的命令.来看看git reset命令用法. --------------------------------------- ...

  5. 我对git的快速使用和理解

    收藏较好的,分享给大家 https://mp.weixin.qq.com/s/k4tU8snvssyKJ2WkvkFrZA

  6. git plumbing 更加底层命令解析-深入理解GIT

    原文: http://rypress.com/tutorials/git/plumbing 本文详细介绍GIT Plumbing--更加底层的git命令,你将会对git在内部是如何管理和呈现一个项目r ...

  7. 理解 Git

    Git 如何保存文件 其它版本管理系统通常会保存所有文件及其历次提交的差异(diff / revision),通过 merge 原始文件与各阶段的差异就能获取任何版本的状态 而 Git 保存的是每一次 ...

  8. 版本控制Git(1)——理解暂存区

    一.svn和Git的比较 我们都知道传统的源代码管理都是以服务器为中心的,每个开发者都直接连在中间服务器上, 本地修改,然后commit到svn服务器上.这种做法看似完美,但是有致命的缺陷. 1. 开 ...

  9. git的使用理解(分支合并的使用理解,多人编程的解决方案)

    本文主要记录了对git日常使用的一些理解,主要是对git分支的一些感悟. git强大的版本控制系统,之前也使用过SVN,感觉上git对于多人开发的版本控制更加强大,特别是最近对git分支的使用,更是深 ...

随机推荐

  1. javaScript今日总结

    javascript简单介绍ECMAScript 1.语法 2.变量:只能使用var定义,如果在函数的内容使用var定义,那么它是一个局部变量,如果没有使用var它是一个全局的.弱类型! 3.数据类型 ...

  2. 信安周报-第02周:SQL基础

    信安之路 第02周 Code:https://github.com/lotapp/BaseCode/tree/master/safe 前言 本周需要自行研究学习的任务贴一下: 1.概念(推荐) 数据库 ...

  3. C语言连接mysql,用GCC编译

    1. main.c文件内容如下 #include <stdlib.h>#include <stdio.h>#include <winsock.h>#include ...

  4. 用python写排序算法

    希尔排序 希尔排序通过将比较的全部元素分为几个区域来提升插入排序的性能.这样可以让一个元素可以一次性地朝最终位置前进一大步.然后算法再取越来越小的步长进行排序,算法的最后一步就是普通的插入排序,但是到 ...

  5. netty源码解解析(4.0)-18 ChannelHandler: codec--编解码框架

    编解码框架和一些常用的实现位于io.netty.handler.codec包中. 编解码框架包含两部分:Byte流和特定类型数据之间的编解码,也叫序列化和反序列化.不类型数据之间的转换. 下图是编解码 ...

  6. 设计一个完美的http缓存策略

    1.前言 作为一个前端,了解http缓存是非常必要,它不仅是面试的必要环节,也更是实战开发中必不可少需要了解的知识点,本文作者将从缓存的概念讲到如何在业务中设计一个合理的缓存架构,带你一步一步解开ht ...

  7. 登录cookies

    cookie Cookie 是指某些网站服务器为了辨别用户身份和进行Session跟踪,而储存在用户浏览器上的文本文件,Cookie可以保持登录信息到用户下次与服务器的会话./p> cookie ...

  8. 纯数据结构Java实现(4/11)(BST)

    个人感觉,BST(二叉查找树)应该是众多常见树的爸爸,而不是弟弟,尽管相比较而言,它比较简单. 二叉树基础 理论定义,代码定义,满,完全等定义 不同于线性结构,树结构用于存储的话,通常操作效率更高.就 ...

  9. json模块和pickle模块

    json模块和pickle模块 一.json模块 作用:用python写了一个程序,用java写了一门程序,这两个程序需要数据之间交流,就产生了一种多种语言通用的数据类型,json串. 序列化:把对象 ...

  10. import 和from…import

    import 和from-import 一.import模块名 import time print(time.time()) import首次导入模块发生了3件事: 使用import time导入的时 ...