用思维导图的形式学习Git,本文只是整理了git快速使用的导图,如果想要更深入的理解git,或者完成更加复杂的操作,需要系统性的学习。
注:思维导图的最后是终端命令,由于字体的关系--连成一起,读者看到长的-其实就是--
在使用git前,可以看看我整理的终端中最基本的文件操作:
Git简介
一种分布式版本管理工具
版本工具:用来管理一个文件夹中文件内容的变更,并记录下每个版本。
版本工具分类:1.分布式 2.集中式
集中式版本控制:SVN等、适合公司里用,服务器管理,每个人的版本都是提交到服务器,以服务器为主,服务器坏了就拉不到。
分布式版本控制:安全,每人本地有个版本库,每个人都可以充当‘服务器’
我主要把Git分成下面几个大类
1.版本库
什么是版本库?
一个文件仓库,仓库里面的文件的增删改,git都能跟踪到。
那怎么才能追踪文件的变化呢?---->创建版本库
当创建了一个版本库,那么就会生成一个.git的文件,这个文件就是用来追踪版本的,千万不要没事去动它
本地在提交到版本库前,会先进入暂存区,再提交到版本库。
2.版本之间的穿梭
Git在不同版本之间可以穿梭,通过版本号和次序。
版本列表中会带有版本号,这个版本号可以指定版本回退
当你回退过版本,并不会导致,你回退前的版本消失,它还在,你可以撤销回退。
由这幅图能看出,版本库的撤销可以通过回退版本,而暂存区,则可以细分回退,单个文件回退。
3.分支
创建与合并分支
使用git可以设计适用不同团队的分支策略,推荐大家看一下gitflow,有一套很不错的项目分支策略,和基于git的更加简单的代码
当一个分支没有commit的时候,是不能切换到其他的分支的。
stash储藏工作现场
当你手头的代码写了一半,这个时候你的老大叫你马上切回develop,修改一个紧急的BUG,这个时候提交到暂存区不是个好的方法,那么久用到stash操作,它可以保存工作现场,让你可以切换到其他的分支去,等在其他分支解决完BUG,再回来,可以恢复工作现场
多人协作
4.版本标签
用来记录众多提交的小版本中,重大意义的版本(打包上传APP活安卓市场)对应的版本,这样一来,就可以找到历史中是哪个是大版本了。