6. git rev-parse
准备工作
在工作区中建立目录 a/b/c ,进入该目录中。
cd /path/to/my/workspace/demo/ mkdir -p a/b/c cd /path/to/my/workspace/demo/a/b/c
显示版本库 .git 目录所在的位置。
$ git rev-parse --git-dir /path/to/my/workspace/demo/.git
显示工作区根目录。
$ git rev-parse --show-toplevel /path/to/my/workspace/demo
显示相对于工作区根目录的相对目录。
$ git rev-parse --show-prefix a/b/c
显示从当前目录(cd)后退(up)到工作区的根的深度。
$ git rev-parse --show-cdup ../../..
git rev-parse HEAD
获取当前最后一个的 commit hash
$ [master] git rev-parse HEAD 51834cc95f15c81b1d8c6afc2625e50a81aadb23
面命令中的HEAD可以替换成branch name,如git rev-parse dev
获取dev分支的最后一次提交
git rev-parse --abbrev-ref
HEAD获取当前分支名
$ [master] git rev-parse --abbrev-ref HEAD master
上面命令都说是获取当前的XX,也就是说你运行命令时所在的 git 目录,如果在任何目录运行可以获取当前的XX,需要明确指出.git
目录的位置以及git对应的工作目录。
$ git --git-dir='./maleskine/.git' rev-parse --abbrev-ref HEAD master
通过设置--git-dir
选项,也可以正确的获取到maleskine
项目当前的分支名。git还有一个选项--work-tree
可以指定git的工作目录。
7. git reset
git reset --hard logid(logid的前几位即可) --将版本库还原到历史的某个时刻的状态 git reset --hard HEAD^ --将版本库还原到上一次commit之前的状态 #有时候,进行了错误的提交,但是还没有push到远程分支,想要撤销本次提交,可以使用git reset –-soft/hard命令。 git reset –-soft:回退到某个版本,只回退了commit的信息,代码修改过的没变。如果还要提交,直接commit即可; git reset -–hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容,撤销的commit中所包含的更改被冲掉,即commit与修改过代码都撤销,变为原来的某个版本;
8. git config
git config --global user.name 'username' --添加版本库的用户名到本地配置文件 git config --global user.emal 'emal' --添加版本库的用户邮箱到本地配置文件
9. git diff
执行 git diff 来查看执行 git status 的结果的详细信息。
git diff 命令显示已写入缓存与已修改但尚未写入缓存的改动的区别
尚未缓存的改动:
git diff
查看已缓存的改动:
git diff --cached
查看已缓存的与未缓存的所有改动:
git diff HEAD
显示摘要而非整个 diff:
git diff --stat
实例;
git status -s git diff git add hello.php git status -s git diff --cached
10. git commit
git commit -m 'test comment from w3cschool.cn' git add 提交缓存的流程太过繁琐,Git 也允许你用 -a 选项跳过这一步 git commit -am 'changes to hello file' git commit --signoff -m 'xxx' // 表示提交的信息中带有署名信息; git commit --amend 'xxx' // 表示对上一次提交的信息,进行修改提交;
11 git rm
git rm 将文件从缓存区中移除 git rm hello.php git rm file 会将文件从缓存区和你的硬盘中(工作目录)删除。 如果要在工作目录中留着该文件 git rm --cached
12 git log
git log 查看提交历史 git log --oneline --oneline 选项来查看历史记录的简洁的版本 git log --oneline --graph -graph 选项,查看历史中什么时候出现了分支、合并。 git log --reverse --oneline '--reverse'参数来逆向显示所有日志 git log --author=Linus --oneline -5 --author , 例如,比方说我们要找 Git 源码中 Linus 提交的部分 git log --oneline --before={3.weeks.ago} --after={2010-04-18} --no-merges
13 git tag
git tag #查看所有标签
-a 选项意为"创建一个带注解的标签"。 不用 -a 选项也可以执行的,但它不会记录这标签是啥时候打的,谁打的,也不会让你添加个标签的注解
git tag -a v1.0 git log --oneline --decorate --graph --decorate 时,我们可以看到我们的标签
追加标签
git tag -a v0.9 85fc7e7 git log --oneline --decorate --graph
指定标签信息命令:
git tag -a <tagname> -m "w3cschool.cn标签"
PGP签名标签命令:
git tag -s <tagname> -m "w3cschool.cn标签"