github 进阶说明
github 进阶说明
前言
我们可以什么都不管,照搬命令来完成我们大部分git工作,但是如果想要进一步,就要深入理解git的实现原理,和底层机制。
三个目录树
- HEAD 仓库指针
- index file 暂存区
- Working Directory 工作目录
默认情况,头指针会指向当前分支,当前分支指向当前目录树。所谓目录树简而言之就是一个commit对象,保存了某个提交时刻的工作目录内容的镜像。而工作目录就是当前文件内容。
状态一:初始情况是三者相同。
状态二:当你编辑了工作目录下的内容,工作目录和暂存区就不同。git status会提示你git add相关文件。
状态三:git add 之后,暂存区和仓库又不相同了,git status 提示你git commit,当你git commit之后,回到状态一,仓库就增加了一个新的版本,当前分支指针移动到新版本之上。
周而复始。
重置 git reset
但总有需要重置的时候:
git reset移动当前分支指针(即间接改变HEAD)。
手段一:git reset --soft HEAD~移动HEAD指针到HEAD~,这时仓库和暂存区不同,暂存区和工作目录相同,即状态三。简而言之,就是“撤销”了上次的提交。
手段二:git reset --mixed HEAD~ 移动HEAD指针到HEAD~,并重置暂存区。这时仓库和暂存区相同,工作区和暂存区不同,即进入状态二。--mixed是默认参数。
手段三:git reset --hard HEAD~ 移动HEAD指针到HEAD~,并重置暂存区和工作区到当前HEAD版本。即状态一。这是一条危险操作,因为你可能会丢失当前正在编辑而没提交的所有内容。但这条命令也是真正完全的实现了跳跃版本,不会残留任何一点当前版本的信息。
增加路径的reset
reset可以增加路径,这时的表现就是重置某个文件而已。并不会改动HEAD指针。
git reset -- file.txt 重置暂存区file.txt文件状态。简而言之,就是git add的反向操作。
你还能指定暂存区重置到哪个版本git reset 234b file.txt。
检出 checkout
checkout和reset命令很相似,也是操控三个目录树。差别是checkout 改变HEAD本身,reset是改变当前被HEAD指向的分支。务必理解这个二重指针的结构。
比如HEAD 指向master,reset 会改变master,HEAD不变。而checkout 会直接改变HEAD,master不变。虽然表面现象上来说很多时候表现是差不多的,因为当前用户可能只会观察到三棵树的变化,而没有留意指针的变化。
git checkout develop 从master分支切换到develop分支,并重置工作区和暂存区,进入状态一。
带路径的checkout
类似带路径的reset,并不会改变HEAD,不同点它重置暂存区,同时也重置工作区。
git checkout -- file.txt 用当前HEAD指向的目录树中的file.txt镜像重置暂存区和工作区。
仓库
- 纯仓库。
git init --bare创建一个纯仓库,只是用来存储仓库数据而不是用来工作的。比如用来做服务器远端仓库,本地仓库的备份。 - 空仓库。
git init创建一个空仓库
仓库内容:ls -F1 .git
branches/ #分支
COMMIT_EDITMSG
COMMIT_EDITMSG.save
config #设置
description #GitWeb使用
FETCH_HEAD
gitk.cache
HEAD #头指针
hooks/ #钩子
index #暂存区
info/ #全局排除模式,类似.gitignore
logs/
objects/ #数据
ORIG_HEAD
refs/ #各种commit 指针
数据对象
git hash-object任何对象都可以用哈希值加入仓库索引git cat-file用哈希值搜索仓库内对象git update-index --add --cachinfo 100644更新暂存区对象git write-tree将暂存区写入树对象git read-tree --prefix=dir加入子树,前缀dirgit commit-tree c03ca4用树对象生成提交对象git log --stat查看提交对象历史信息git fsck --full查看没有引用的对象git gc压缩对象库git count-objects -v查看空间暂用统计git prune --expire now立即清除所有不被引用的对象(因为试验,生成了错误的对象,但是要清理非常非常麻烦,最后靠这条命令成功清理了)git reflog expire --expire-unreachable=0 --all清理操作记录,这是对象有可能被引用的地方
其他
git config core.autocrlf true自动转换换行格式。
资料
git社区参考书:http://gitbook.liuhui998.com/
github 进阶说明的更多相关文章
- GitHub进阶之利用Git远程仓库篇
#在上一篇文章,相信大家对GitHub已经有了一个基础的理解 接下来我们来学习一下如何利用git来远程仓库 一,git是什么 git:一个免费的开源版本控制软件 用途:利用Git管理GitHub上的代 ...
- 搜刮一些开源项目的APP
iOS完整App资源收集 <iOS完整app资源收集> <GitHub 上有哪些完整的 iOS-App 源码值得参考?> <GitHub 上有哪些完整的 iOS-App ...
- github+hexo搭建自己的博客网站(六)进阶配置(搜索引擎收录,优化你的url)
详细的可以查看hexo博客的演示:https://saucxs.github.io/ 绑定了域名: http://www.chengxinsong.cn hexo+github博客网站源码(可以clo ...
- 服务端技术进阶(八)GitHub入门篇
服务端技术进阶(八)GitHub入门篇 前言 在投递简历的过程中,发现有的公司会要求填写自己的GitHub地址,而自己却还没有GitHub帐号,准确点说是自己还不太会使用GitHub.(貌似开源社区中 ...
- 使用Hexo+Github搭建属于自己的博客(进阶)
主题的配置:这里以NexT主题作为题材 1.安装NexT,在其文件夹中鼠标右键,点击Git Base Here.输入命令:git clone https://github.com/iissnan/he ...
- 从0开始学习 GITHUB 系列之「GIT 进阶」【转】
本文转载自:http://stormzhang.com/github/2016/06/16/learn-github-from-zero5/ 版权声明:本文为 stormzhang 原创文章,可以随意 ...
- 转 从红帽、GitHub和Docker看开源商业模式的进阶
从红帽.GitHub和Docker看开源商业模式的进阶 发表于2014-12-16 10:26| 7594次阅读| 来源http://stratechery.com/| 0 条评论| 作者Ben Th ...
- 从0开始学习 GitHub 系列之「05.Git 进阶」
关于 Git 相信大家看了之前一系列的文章已经初步会使用了, 但是关于Git还有很多知识与技巧是你不知道的,今天就来给大家介绍下一些 Git 进阶的知识. 1. 用户名和邮箱 我们知道我们进行的每一次 ...
- OkHttp使用进阶 译自OkHttp Github官方教程
版权声明: 欢迎转载,但请保留文章原始出处 作者:GavinCT 出处:http://www.cnblogs.com/ct2011/p/3997368.html 没有使用过OkHttp的,可以先看Ok ...
随机推荐
- Java高并发之无锁与Atomic源码分析
目录 CAS原理 AtomicInteger Unsafe AtomicReference AtomicStampedReference AtomicIntegerArray AtomicIntege ...
- PAT1082:Read Number in Chinese
1082. Read Number in Chinese (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yu ...
- SSM-MyBatis-02:Mybatis最基础的增删改查(查全部和查单独一个)
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 继续上次的开始,这次记录的是增删改查,上次重复过的代码不做过多解释 首先先创建mysql的表和实体类Book ...
- Linux共享库、静态库、动态库详解
1. 介绍 使用GNU的工具我们如何在Linux下创建自己的程序函数库?一个“程序函数库”简单的说就是一个文件包含了一些编译好的代码和数据,这些编译好的代码和数据可以在事后供其他的程序使用.程序函数库 ...
- PHP 的 uniqid 函数产生的 id 真的是唯一的么?
PHP 的 uniqid 函数产生的 id 真的是唯一的么? 最近使用到了 uniqid,就产生了疑问?uniqid 生成的 id 由什么组成?真的是唯一的么?什么情况下会产生冲突? 从文档中看到 u ...
- Centos7 环境下 tty 终端 中文乱码 问题
最近有同学问我 Centos 方面的一些操作, 由于我已经好多年不用Centos了所以比较生疏,这些年来一直都是用Ubuntu的,不得不说Ubuntu是我用过的这么多Linux系统中操作最舒服的了, ...
- 跟我学ASP.NET MVC之六:SportsStrore添加产品目录导航
摘要: 上一篇文章,我建立了SportsStore应用程序的核心架构.现在我将使用这个架构向这个应用程序添加功能,你将开始看到这个基础架构的作用.我将添加重要的面向客户的简单功能,在这个过程中,你将看 ...
- JAVA经典算法40题(原题+分析)之分析
JAVA经典算法40题(下) [程序1] 有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分析: ...
- stop_token.go
package engine import ( "bufio" "log" "os" ) type StopToke ...
- 理解Go Context机制
1 什么是Context 最近在公司分析gRPC源码,proto文件生成的代码,接口函数第一个参数统一是ctx context.Context接口,公司不少同事都不了解这样设计的出发点是什么,其实我也 ...