Git的化粪池

>分布式版本控制系统

什么是分布式版本控制系统,版本控制系统或许大家都知道,古典的程序员都有用过subversion,而svn是集中式的版本控制系统,而Git是分布式的版本控制系统,那么什么是分布式的,传统的比如svn都是将版本库放在服务器端,而Git则是将版本库放在了本地,这使得我们能够在不联网的时候在本地提交版本。

>Git的管理结构

Git在本地可以说可以分为三部分,如下图:


Git三部分的图片
Git三部分的图片

working directory是我们使用的本地文件,当我们修改这些文件之后,我们能够将这些文件add到暂存区Stage上,当我们提交版本的时候,Git会降Stage上的快照更新到我们提交的版本中去,我们也能够checkout版本库中的信息将我们本地的修改抹去。
接下来我们看看commit的结构:


commit结构图
commit结构图

commit的结构是一个树状结构,每个commit都指向一个tree节点,每个tree节点都指向若干个快照,当我们提交的时候,当前的commit就会指向上一个版本的commit,组成一条链。如图:
commit链图
commit链图

而分支在Git中又是什么呢?当我们创建一个分支的时候其实就是创建一个分支指针,这个指针指向某一个commit,如图:
分支图
分支图

branch1分支就是指向第一个commit,而master分支指向最后一个commit,而所谓的当前分支就是HEAD指针的指向,当当前分支是master的时候,HEAD指针就指向master,并且从master开始遍历commit然后生成最后的文件结构,而当我们切换到branch1得时候HEAD就指向branch1,并从branch1开始遍历,得到一个文件结构。

>常用的Git指令

git init
这个指令用于创建一个git的管理系统,当我们在目录下执行这个指令之后,这个目录就在git的控制下了
git status
这个指令用于查看文件的状态
git add
可以将修改的文件或者新加入的文件放入暂存区stage
git commit
可以将暂存区中的快照集成一个版本提交
git diff
可以查看修改文件和源文件或者两个commit的差距
git remote
可以设置远程库
git push
可以将本地的版本库更新到远程库
git pull
可以将远程库更新到本地
git clone
可以克隆整个版本库到本地
git log
可以查看commit
git checkout
用法非常多!!!!
git revert
恢复到一个版本,并提交一个恢复版本的commit
git branch
创建查看分支
git merge
合并分支
git stash
将修改放入栈中,以便进行先必要操作将来取出

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 声明:这篇文章来源于廖雪峰老师的官方网站,我仅仅是作为学习之用 Git简介 Git是什么? Git是目前世界上最先...
    横渡阅读 3,987评论 3 27
  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 13,721评论 9 163
  • ------------------------------------------------------瞿三 ...
    瞿三阅读 143评论 0 4
  • 诚挚地邀请您关注公众号
    Molly_2250阅读 183评论 0 0
  • 厨不仅仅是一份职业,更是一门技术一门艺术。厨师的传承不仅仅是一项知识文化的传承,更是一种情感的传承。图片发自简书A...
    山朗阅读 1,081评论 0 1