Git版本控制管理学习笔记5-提交
这个标题其实有些让人费解,因为会想这个提交是动词还是名称?
提交动作是通过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-提交的更多相关文章
- Git版本控制管理学习笔记3-基本的Git概念
为了更近一步的学习和理解Git的理念,这一节介绍一下Git中的一些基本概念. 基本概念 对象库图示 Git在工作时的概念 一.基本概念: 1.版本库: Git的版本库就是一个简单的数据库,其中 ...
- Git版本控制管理学习笔记1-介绍
几乎所有的版本控制工具都是出于同样的目的:开发以及维护开发出来的代码,方便读取代码的历史,记录所有的修改.这里,介绍的是当前在开源社区内非常流行的版本控制工具Git.它是由Linus Torvalds ...
- Git版本控制管理学习笔记4-文件管理和索引
可以认为使用Git时,我们会遇到3个空间:工作目录.索引.版本库.我们关心的,就是在新建.修改等操作时,这三者之间发生了怎样的变化. 笼统的讲,就是在工作目录下编辑,在索引中积累修改, ...
- Git版本控制管理学习笔记2--起步
首先确保系统中已经安装了git,这里使用的linux系统. 一.命令行初步使用: 1.git命令: 列出它的选项和最常用的子命令.标准命令格式中,COMMAND代表的就是下面列出的子命令. [root ...
- Git 版本控制工具(学习笔记)
GIT(分布式) 一.Git 初始版本控制工具 1. 安装Git Ubuntu系统下,打开shell界面,输入: sudo apt-get install git-core 之后回车输入密码,即可完 ...
- C++内存管理学习笔记(5)
/****************************************************************/ /* 学习是合作和分享式的! /* Auth ...
- C++内存管理学习笔记(6)
/****************************************************************/ /* 学习是合作和分享式的! /* Auth ...
- C++内存管理学习笔记(7)
/****************************************************************/ /* 学习是合作和分享式的! /* Auth ...
- Docker Image管理学习笔记,ZT
Docker Image管理学习笔记 http://blog.csdn.net/junjun16818/article/details/38423391
随机推荐
- JVM:查看java内存情况命令
jmap (linux下特有,也是很常用的一个命令) 观察运行中的jvm物理内存的占用情况. 参数如下: -heap :打印jvm heap的情况 -histo: 打印jvm heap的直方图.其输出 ...
- 跟我一起学习VIM
跟我一起学习VIM - The Life Changing Editor 前两天同事让我在小组内部分享一下VIM,于是我花了一点时间写了个简短的教程.虽然准备有限,但分享过程中大家大多带着一种惊叹 ...
- iTunes Connect 显示可供销售,但是AppStore 就是不显示新版本(异于往常版本更新)
这次版本更新,从上传到审核通过不足8小时.由于是手动发布,第二天早上上班发布了新版本.但是不同于往常,这次等了很久也不见AppStore 更新新版本.检查一下iTunes Connect ,显示可供销 ...
- iOS 判断网络连接状态的几种方法
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px "PingFang SC"; color: #801b80 } p.p2 ...
- Spring学习记录1--@Transactional Propagation
起因 学习Spring的时候就知道aop有一个应用是声明式注解..反正往Service上一丢@Transactional就完事了..不用自己去开启hibernate的session,很简单. 但是@T ...
- mac显示隐藏文件
苹果Mac OS X操作系统下,隐藏文件是否显示有很多种设置方法,最简单的要算在Mac终端输入命令. 显示/隐藏Mac隐藏文件命令如下(注意其中的空格并且区分大小写): 第一种 显示Mac隐藏文件的命 ...
- java初始化
一.成员初始化 1.成员变量没有赋值,则被初始化成默认值. 2.局部变量没有赋值,编译时报错. 二.构造器初始化 1.成员变量在构造器初始化之前,已经被初始化. 2.变量定义的顺序决定了初始化的顺序. ...
- Appcan——Box
Box架构 ub….. Box架构元素空间大小分配比例 ub-f……. Ub-f1,ub-f2,ub-f3……. Box架构元素垂直方向的位置排列 ub-ac,ub-ae… -webkit-box-a ...
- jquery_DOM笔记3
css 操作: css()设置或者返回匹配元素的样式 height() 设置或者返回匹配元素的高度 width() 设置或者返回匹配元素的宽度 offset()设置或者返回匹配元素相对于文档的相对位置 ...
- react+redux官方实例TODO从最简单的入门(6)-- 完结
通过实现了增-->删-->改-->查,对react结合redux的机制差不多已经了解,那么把剩下的功能一起完成吧 全选 1.声明状态,这个是全选状态 2.action约定 3.red ...