git简介
git是一款开源的分布式版本管理工具,git的诞生也是相当传奇的,由Linux之父-Linus Benedict Torvalds开发而来,当初Linus Benedict Torvalds仅仅是为了辅助Linux内核的开发才一并开发了这个至今为止世界上最快的、最简单的版本管理工具。
git原理
首先要明确一点: git中一切都是文件(Unix系统理念)
git是分布式的版本管理工具,每一个工作者本地都有一个中心仓库,同时在远程分支是还有一个中心仓库,平时开发时的操作(add,commit)都是对本地分支进行操作。当开发完一个功能或解决完bug后就需要把本地的修改同步到远程分支中(push ,pull)。这样每个工作者就可以在本地同时开发,只需在同步时做好合并工作就可以。可以很大的提高工作效率,而且出错也很少。
Git 的工作就是创建和保存你的项目的快照及与之后的快照进行对比。
git一共分为三个部分工作区(workingCopy)、暂存区(stage)、中心仓库(master)
当平时修改代码时改动的是工作区,使用git add命令时就会把工作区的修改保存在暂存区,使用git commit 命令会把暂存区的修改提交到本地仓库。使用push会将本地仓库的提交同步到远程仓库。所以流程是workingCopy ------->stage ------>master ------>remote。
注意:git stash 命令是新开辟一个栈来保存工作区的改动,不会添加到暂存区。
git是以指针为基础的,存储在 git 中的所有东西都包含在一个文件中。当你提交的时候,git 会创建一个包含提交消息和相关数据的文件(名称、邮件、日期/时间、上一次提交等等),并将其链接到一个树形文件。树形文件包含一个对象列表或者其它树。对象或二进制大数据对象(BLOB)是提交的真正内容(虽然文件名没有存储在对象中,但会存储在树中)。所有这些文件都以对象的 SHA-1 哈希为文件名进行存储。
分支和标签只是一些文件,这些文件包含(基本上)一个指向提交的 SHA-1 哈希值。使用这些引用在灵活性和速度上均有大幅提升,创建一个新的分支就和创建一个文件一样简单,只是这个文件带有分支名称和一个包含指向提交(你从这个提交建立分支)的SHA-1哈希值。