基本概念:
Git对象:
查看对象类型
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/目录下所有的文件