git学习

TODO--持续更新经常使用的

基本概念:##

Git对象:

git cat-file

查看对象类型###

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 checkout -- 文件名

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: leave welcome.txt alone
7250a94 master@{2}: merge 7250a: Fast-forward
a2d0352 master@{3}: commit: 5th commit
67fba85 master@{4}: master@{3}: updating HEAD

重置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/ 目录下所有的文件
posted @ 2014-04-02 23:31  wjch  阅读(1347)  评论(0编辑  收藏  举报