参考:https://www.liaoxuefeng.com/wiki/896043488029600

一)、git的使用:

1.创建版本库(Resopsitory),相当于一个目录,目录中所有的文件被git管理,每个文件的修改跟删除操作都会被跟踪监控。

.git : 跟踪管理版本库

注: 所有版本控制器只能跟踪文本的改动,如:.txt文件,网页,以及程序代码等

二)、git的命令

git log : 查看从最近到最远的提交日志

git checkout: 切换到另一个分支

git checkout --:修改命令

git reset : 回退版本,也可以把暂存区的修改回退到工作区

注:*将暂存区的数据提交到.git版本库即master分支还能够回退一节,====》能

      但需要一条件:即:没有把本地版本库推送到远程

$git push origin master: 将本地分支的最新修改推送至远程仓库

三)、使用可视化工具查看git历史

HEAD:当前版本

HEAD^: 上个版本

HEAD^^: 上上个版本

HEAD~100: 在往上100个版本

git reset: 回退到上一个版本

git的工作区和暂存区

工作区:创建的版本库

git init命令把这个创建的版本库变成Git可以管理的仓库

.git : git的版本库,执行git init命令后,会在创建的版本库目录下自动生成.git文件

四)、添加远程仓库

步骤

  1. 本地创建一个git仓库
  2. 在gitHub创建一个仓库(该仓库作为备份,其它人通过该仓库协作)
  3. 在本地仓库下运行命令关联gitHub的git仓库
  4. 将本地的内容推送到远程库

    通过$git push origin master: 将本地分支的最新修改推送至github

五)、git的代码提交流程

  1. 通过git add : 将文件放置暂存区中
  2. 使用git commit: 将暂存区中的文件放置在分支中

    文件 ------ 》暂存区 --------》分支

    注:可以add多个文件到暂存区(stage),一次性提交到分支上(master)

    创建版本库时,会自动的创建一个唯一的master

六)、git的分支管理

HEDA:当前版本 ------->master(分支) --------->最新提交

创建dev新分支

增加dev指针:

HEDA(当前版本) ------->dev --------》最新提交

master-----》最新提交

dev分支的修改提交更新

当对工作区的修改提交后,dev分支移动,指向最新的的提交,master指向不变对,

此时对工作区的修改和提交就是针对dev分支了

dev分支工作完毕,合并主分支master

master指向dev的最新提交 ,HEAD指向master

HEAD ----> master ------>dev的最新提交

七)、git的优点:

定义:分布式版本控制系统

  1. 不联网也能工作
  2. 分支管理

Git的使用和基本概念理解的更多相关文章

  1. git 入门教程之基本概念

    基本概念 了解工作区,暂存区和版本库的区别和联系有助于我们更好理解 git 的工作流程,了解命令的操作意图. git 和其他版本控制系统如 svn 的不同之处就是有暂存区的概念. 基本概念 工作区 | ...

  2. git 命令(提高篇)的本质理解

    上一篇博客:[[git 命令(提高篇)的本质理解] (http://www.cnblogs.com/juking/p/7105744.html)]介绍了Git 的基础知识 -- 提交.分支以及在提交树 ...

  3. 大数据核心知识点:Hbase、Spark、Hive、MapReduce概念理解,特点及机制

    今天,上海尚学堂大数据培训班毕业的一位学生去参加易普软件公司面试,应聘的职位是大数据开发.面试官问了他10个问题,主要集中在Hbase.Spark.Hive和MapReduce上,基础概念.特点.应用 ...

  4. SpringIOC的概念理解、构造器注入、setter注入、p命名空间注入、IOC容器介绍与比较

    1.IOC概念理解 IOC(Inversion of Control)即“控制反转”,不是什么技术,而是一种设计思想.在Java开发中,Ioc意味着将你设计好的对象交给容器控制,而不是传统的在你的对象 ...

  5. Kubernetes重要概念理解

    Kubernetes重要概念理解 kubernetes是目前最主流的容器编排工具,是下一代分布式架构的王者.2018年的kubernetes第一个版本1.10已经发布.下面整理一下,kubernete ...

  6. SNF快速开发平台2019-角色、权限、账户的概念理解-非常全的理论讲解权限控制

    组织模型   资源模型  操作模型 谁能够执行哪些操作    执行资源的范围 资源概念资源就是想要的到的最终物质,我们可以给每一个资源定义一个权限,也可以给某一类资源定义一个权限 权限概念权限是对资源 ...

  7. elasticsearch基本概念理解+elasticsearch 的shards unassigned处理方法 -- 最佳运维实践 - 集群规划

    1.es与MySQL的概念对比 2.概念理解 2.1 Index : 一个索引即是文档的集合 2.2 Document : 一个文档即是一个可被索引的基础单元信息,一条记录: 2.3 Replicas ...

  8. fragment概念理解

    fragment概念理解知识,fragment概念理解图片 fragment概念理解内容,fragment概念理介绍,fragment概念理正文 Fragment是Android honeycomb ...

  9. ubuntn系统下将文件拷贝到优盘中及挂载概念理解

    参考资料:http://jingyan.baidu.com/article/7082dc1c76f178e40a89bdd3.html: http://bbs.csdn.net/topics/3801 ...

随机推荐

  1. JavaScript 变量作用域和声明提升

    一.变量作用域 说到这个概念,不有自主的想到this,scope 这两个关键字. JavaScript的this总是指向一个明确的对象,这个对象是在执行的时候动态绑定的.通俗的说就是谁调用我,我的th ...

  2. Spring Cloud Feign初接触

    最近想使用下Feign,然后简单了解了一下,简单的搭了个demo. 首先简单介绍一下Feign,它是一个Http请求客户端,类似HttpClient,具体里面实现还没去看,知道它是一个请求客户端就行, ...

  3. 设计模式(十二)Decorator模式

    Decorator模式就是不断地为对象添加装饰的设计模式.以蛋糕为例,程序中的对象就相当于蛋糕,然后像不断地装饰蛋糕一样地不断地对其增加功能,它就变成了使用目的更加明确的对象. 首先看示例程序的类图. ...

  4. (二)Kinect关节识别

    基础:添加KinectManager 组件 1)局部关节获取(参考插件场景KinectOverlayDemo1) 要获取局部某一关节及其位置,添加脚本JointOverlayer即可,通过Tracke ...

  5. fenby C语言 P28

    #include <stdio.h> int main(){ int *p1,*p2,a=10,b=20,c; p1=&a; p2=&b; if(a<b) { c=a ...

  6. fenby C语言 P18

    #include <stdio.h> int main(){ int i; for(i=1;i<=15;i++) { if((i%2==1)) { printf("%d\n ...

  7. git 命令归纳版

    1.克隆: 单纯的克隆名字: git clone [url] 自定义新建项目名称: git clone [url] [项目名字]   2.跟踪文件: git add [文件名]   3.添加忽略文件 ...

  8. 学习笔记39_EF的DAL层(精)

    通用的分页查询 public IQueryable<UserInfo> GetPage<T>(int pageSize,int pageIndex,out int total, ...

  9. 2019 .NET China Conf:路一直都在,社区会更好

    这个周末,我从成都飞到了上海参加了首届由社区组织而非官方(比如Microsoft)组织的.NET开发者峰会(.NET Conf).为此,我特意请了两天的假(周五+周六,对,我们是大小周,这周六要上班) ...

  10. 《吊打面试官》系列-Redis哨兵、持久化、主从、手撕LRU

    你知道的越多,你不知道的越多 点赞再看,养成习惯 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难.作为一个在互联 ...