>分布式版本控制系统
什么是分布式版本控制系统,版本控制系统或许大家都知道,古典的程序员都有用过subversion,而svn是集中式的版本控制系统,而Git是分布式的版本控制系统,那么什么是分布式的,传统的比如svn都是将版本库放在服务器端,而Git则是将版本库放在了本地,这使得我们能够在不联网的时候在本地提交版本。
>Git的管理结构
Git在本地可以说可以分为三部分,如下图:
working directory是我们使用的本地文件,当我们修改这些文件之后,我们能够将这些文件add到暂存区Stage上,当我们提交版本的时候,Git会降Stage上的快照更新到我们提交的版本中去,我们也能够checkout版本库中的信息将我们本地的修改抹去。
接下来我们看看commit的结构:
commit的结构是一个树状结构,每个commit都指向一个tree节点,每个tree节点都指向若干个快照,当我们提交的时候,当前的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
将修改放入栈中,以便进行先必要操作将来取出