看了廖雪峰的git教程,很详细,并且小结很到位,在此自己再根据需要总结一下,方便今后操作查阅,详情可看git教程
PS:紧记Git跟踪并管理的是修改,而非文件。
1. 创建版本库
git init --> 初始化一个Git仓库
添加文件到git仓库分2步:
- git add <file>
- git commit -m <message> ps:-m后面输入的是本次提交的有意义说明
2.版本回退(后悔药)
Git允许我们在版本的历史之间穿梭 git reset --hard commit_id
- 回到过去,使用 git log 查看 commit_id
- 重返未来,使用 git reflog 查看commit_id
3.工作区、暂存区、版本库的概念
Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。
- 工作区:电脑里能看到的目录
- 暂存区: stage/index ,存放在 ".git目录下" 下的index文件(.git/index)中,so,也可叫作索引(index)
- 版本库:工作区有个隐藏目录.giit ,是Git的版本库
修改提交及chexiu操作流程:
工作区-- git add <file>
---> 暂存区 --git commit -m <meg>
--> 版本库
版本库--版本回退(未推送到远程库)-->暂存区--git reset head <file>
-->工作区--git checkout -- file
-->丢弃工作区的修改
简言之,撤销修改可分4种
1.没有git add时,用git checkout -- file
2.已经git add时,先git reset HEAD <file>回退到1.,再按1.操作
3.已经git commit时,用git reset回退版本
4.如已推送到远程库,GG?
这里说说较为难理解的一个点----暂存区
暂存区如概念所说是一个index文件
-
git init 初始化仓库的时候会生成一个文件夹.git(普遍隐藏,可设置显示隐藏文件夹),里面内容如下
-
添加一个文本text1,并执行
git add .
操作,.git下多了个index文件,它就是一个暂存区,也被成为索引 index -
执行
git status
,可见文件被修改,处于暂存区待提交commit状态 -
此时再来看看暂存区的内容
git ls-files --stage
-
新增文件text2,并新增到暂存区,再次查看暂存区内容
这下便可理解,为何暂存区被称为索引(index)-- 指向文件的索引
而真正的文件是存储在.git/objects目录,这里不详说,具体可查阅官方资料-
下面将所有文件提交,查看工作区、暂存区的状态,查看暂存区的内容
由此可见commit后工作区没有新增/修改的文件,暂存区也没有待提交的文件,暂存区内容不变,并不像我们感性上的被清空,如真的需要删除暂存区的内容,其实就是删除index文件的内容,存储在.git/objects目录下的真正文件是不会被删除的,如想删除真正的文件,操作git rm --cached <file>
-
在理解了暂存区的基础上,我们就能很好的理解了以下命令