基本概念:

查看对象类型

git log –pretty=raw –graph e672332

打印提交对象之间的互相关联的跟踪链,–pragh显示parent属性,没有parent即为起点

显示当前分支

git branch

HEAD,master分支,和refs/heads/master区别

使用master代表分支master中最新的提交,也可以使用全称refs/heads/master或heads/master

使用HEAD代表版本库中最近的一次提交

符号^可以用来只带父提交,如:

HEAD^代表版本库的上一次提交,即最近一次提交的父提交(即倒数第二次提交)

HEAD^^代表HEAD^的父提交

Git重置

git reset可以将游标指向任意一个存在的提交ID

git reset –hard HEAD^将master重置到上一个老的提交中,此时提交历史也会改变

使用git reset重置命令很危险,会彻底的丢失历史

使用Git reflog来挽回错误的重置

git reflog show master |head -5

7250a94 master@{0}: HEAD^: updating HEAD

df208c4 master@{1}: commit: leavewelcome.txt alone

7250a94 master@{2}: merge 7250a:Fast-forward

a2d0352 master@{3}: commit: 5th commit

67fba85 master@{4}: master@{3}: updatingHEAD

重置master为2次提交之前的值:

git reset –hard master@{2}

git检出

git branch -v查看当前分支

git chackout master切换到master分支上

git checkout branch检出branch分支

git merge ac23224将处于分离头指针状态的提交于当前分支合并

基本操作:

删除文件:

git rm ww.txt在版本库的最新提交中删除文件,在历史提交中还在。而直接在工作区删除文件,对暂存区和版本库没有任何影响。

移动文件:

直接先使用linux的重命名:mv welcome.txt README

然后添加即可: git add -A

回复删除的文件:

最简洁实用的语句:git checkout HEAD~1 – welcome.txt

选择性添加文件:

git add -i使用交互式界面添加文件

文件忽略:

.gitignore的作用范围时其所出的目录及其子目录

Git的文件忽略只是对未入库(untrack)的文件起作用

Git的忽略语法:

1.忽略文件中的空行或以#开始的行会被忽略

2.可以使用通配符,*代表任意多字符,?代表单字符,[abc]代表可选字符范围

3.如果名称的最前面是一个路径分隔符(/),表明要忽略的文件在此目录下,而非子目录的文件

4.如果名称的最后面是一个路径操作符(/),表明要忽略的是一整个目录,同名文件不忽略,否则(即没有/的话)同名的文件和目录都忽略。

5.在名称的最前面添加一个感叹号(!),代表不忽略

如:

*.a #忽略所有以.a为扩展名的文件

!lib.a #但是lib.a文件或目录不要忽略,即使是前面设置了对*.a的忽略

doc/*.txt #忽略文件如doc/notes.txt ,但是文件如doc/serve/arch.txt不被忽略

/TODO #只忽略此目录下的TODO文件,子目录的TODO文件不被忽略

build/ #忽略build/目录下所有的文件