这个标题其实有些让人费解,因为会想这个提交是动词还是名称?

    提交动作是通过git commit命令来实现的,提交之后会在对象库中新增一个提交对象。提交过程中会发生哪些变化,在上一篇笔记里面已经介绍过,看下那几张过程图就可以了。

    需要明确的是,在Git中,版本库的变更和提交是一一对应的关系,也就是说,提交是将变更引入到版本库的唯一方法。

    Git在提交时,会记录索引的快照并把快照存放到对象库中。下一次提交前,就会将当前索引中的状态与上一次生成的快照进行对比,派生出一个受影响的文件和目录列表。

一、原子变更集:

      每一个提交都代表一个相对于之前的状态的单个原子变更集,提交时要么成功,要么全部拒绝。

二、识别提交:

     这一节主要介绍的是提交在Git中的表示方式,包括显式引用和隐式引用。比如,一个40位的SHA1码就是显式引用,HEAD就是一个隐式引用。

     这里将要介绍各种引用的不同书写方法。

  • 绝对提交名:其实就是散列标识符。可以使用下面的命令来查看。
[root@flower1 committest]# git log -1 --pretty=oneline HEAD
2a9b52785b94c45852276c4febb4e05d9e25de1f new data ty
[root@flower1 committest]# git log -1 --pretty=oneline 2a9b
2a9b52785b94c45852276c4febb4e05d9e25de1f new data ty
  • 引用和符号引用:本地特征分支名称、远程跟踪分支名称和标签名都是引用。目录中有3种不同的命名空间表示不同的引用:refs/heads/ref代码本地分支, refs/remotes/ref代表远程跟踪分支,refs/tags/ref代表标签。
[root@flower1 committest]# find .git/refs/
.git/refs/
.git/refs/tags
.git/refs/heads
.git/refs/heads/master
.git/refs/remotes/ref
.git/refs/remotes/ref/HEAD
  • 相对提交名:看下面的例子就知道了。

 

 

 

 

 

 

 

 

 

C^1:等同于C^,表示提交C的第一父提交。

C^2:表示提交C的第二父提交。

C~1:等同于C~,表示提交C的第一个父提交。

C~2:表示提交C的第一个祖父提交。

C~3:表示提交C的第一个曾祖父提交。

C~3^2^2^:表示提交C的第一个曾祖父提交--的--第二父提交--的--第二父提交--的--第一父提交。

这里会用到的git命令如下:

[root@flower1 my_website]# git rev-parse master
e4db73549d3e9289b8ec9c5ec325e1a672942f28
[root@flower1 my_website]# git show-branch --more=35 | tail -10
[master] rename2
[master^] rename
[master~2] test
[master~3] remove
[master~4] test
[master~5] Remove a poem
[master~6] this is poem, the second file added!
[master~7] firsr change
[master~8] Initial contents of public_html
[root@flower1 my_website]# git rev-parse master~6
3df360e031a40a3c7e35856ed4f0b8f63551c89b

 

三、提交历史记录:

1、查看旧提交:

    这里看几个示例命令就行了。

[root@flower1 my_website]# git log master

   [root@flower1 my_website]# git log --pretty=short --abbrev-commit master~6 master~3

   [root@flower1 my_website]# git log --pretty=short --stat master~6 master~4

2、提交图:

 

四、查找提交:

使用下列工具,暂不关注:

  • git bisect
  • git blame
  • Pickaxe

Git版本控制管理学习笔记5-提交的更多相关文章

  1. Git版本控制管理学习笔记3-基本的Git概念

    为了更近一步的学习和理解Git的理念,这一节介绍一下Git中的一些基本概念. 基本概念 对象库图示 Git在工作时的概念 一.基本概念: 1.版本库:     Git的版本库就是一个简单的数据库,其中 ...

  2. Git版本控制管理学习笔记1-介绍

    几乎所有的版本控制工具都是出于同样的目的:开发以及维护开发出来的代码,方便读取代码的历史,记录所有的修改.这里,介绍的是当前在开源社区内非常流行的版本控制工具Git.它是由Linus Torvalds ...

  3. Git版本控制管理学习笔记4-文件管理和索引

        可以认为使用Git时,我们会遇到3个空间:工作目录.索引.版本库.我们关心的,就是在新建.修改等操作时,这三者之间发生了怎样的变化.     笼统的讲,就是在工作目录下编辑,在索引中积累修改, ...

  4. Git版本控制管理学习笔记2--起步

    首先确保系统中已经安装了git,这里使用的linux系统. 一.命令行初步使用: 1.git命令: 列出它的选项和最常用的子命令.标准命令格式中,COMMAND代表的就是下面列出的子命令. [root ...

  5. Git 版本控制工具(学习笔记)

    GIT(分布式) 一.Git 初始版本控制工具 1. 安装Git Ubuntu系统下,打开shell界面,输入: sudo apt-get install git-core  之后回车输入密码,即可完 ...

  6. C++内存管理学习笔记(5)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  7. C++内存管理学习笔记(6)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  8. C++内存管理学习笔记(7)

    /****************************************************************/ /*            学习是合作和分享式的! /* Auth ...

  9. Docker Image管理学习笔记,ZT

    Docker Image管理学习笔记 http://blog.csdn.net/junjun16818/article/details/38423391

随机推荐

  1. Oracle交易流水号问题

    需求:生成交易流水号,每次新增一条记录时都自动加1,且流水号形式为000000001形式的10位数字. 思路:利用序列可以生成自增的流水号,只需要在前面添加N个0即可,同时,由于数字的长度一定,因此可 ...

  2. SpringMVC学习记录4

    主题 SpringMVC有很多很多的注解.其中有2个注解@SessionAttributes @ModelAttribute我平时一般不用,因为实在是太灵活了.但是又有一定限制,用不好容易错.. 最近 ...

  3. 【转载】在IT界取得成功应该知道的10件事

     在IT界取得成功应该知道的10件事 2011-08-11 13:31:30 分类: 项目管理 导读:前面大多数文章都是Jack Wallen写的,这是他的新作,看来要成为NB程序员还要不停的自我总结 ...

  4. SQL Server 2016正式版安装(超多图)

    微软数据库SQL Server 2016正式版在2016年6月就发布,由于近期工作忙,一直拖到现在才有时间把安装过程写到博客上,分享给大家.本人一直习惯使用英文版,所以版本和截图都是英文版的.废话少说 ...

  5. Python数据分析笔记目录

    速查笔记 使用实例 Pandas-数据导入 (未完成) Pandas-数据探索 基础属性 shape indexs columns values dtype/dtypes 汇总和计算描述统计 coun ...

  6. js传入参数为字符串问题

    示例: var device_mac="11qweq234ert"; //第一种方式会报错:Onclick SyntaxError: identifier starts immed ...

  7. 为什么axios请求接口会发起两次请求

    之前在使用axios发现每次调用接口都会有两个请求,第一个请求时option请求,而且看不到请求参数,当时也没注意,只当做是做了一次预请求,判断接口是否通畅,但是最近发现并不是那么回事. 首先我们知道 ...

  8. linux(centOS)下安装Oracle步骤

    ##创建用户和组: [LanRS@localhost ~]$ su root #切换到root Password: [root@localhost LanRS]# groupadd oinstall ...

  9. ACM/ICPC 之 有流量上下界的网络流-Dinic(可做模板)(POJ2396)

    //有流量上下界的网络流 //Time:47Ms Memory:1788K #include<iostream> #include<cstring> #include<c ...

  10. OC编程之道-接口适配之适配器

    已有的类与新的接口之间不兼容的问题相当普遍,人们已为它找到了一个解决方案.这个解决方案就是适配器. 1 何为适配器 what 适配器的主要作用是把被适配者的行为传递给管道另一端的客户端. 将一个类的接 ...