删除设置
git config --unset --global user.name
git config --unset --global user.email
git co
40位十六进制ID
为了保证提交时提交者和作者信息的正确性,需要重新恢复user.name和user.email的设置。
重新修改最新的提交,改正作者和提交的错误信息。
git commit --amend --allow-empty --reset-author
--amend 是对刚刚的提交进行修补,这样就可以改正前面的提交中错误的用户名和邮件
地址,而不会产生另外的新提交。
--allow-empty 使得空白提交被允许。之所以这里必须使用此参数是因为要进行的修补提交
实际上是一个空白提交。
--reset-author 是将Author(提交者)的ID同步修改,否则只会影响提交者(commit)的ID。
使用此参数也会重置AuthorDate信息。
git log --pretty=fuller
git log --stat 参数可以看到每次提交的文件变更统计。
git diff HEAD
HEAD 当前版本库的头指针。
Git暂存区的设计是Git最成功的设计之一,也是最难理解的。
.git 目录下有一个index文件,
执行git checkout 命令,撤销工作区中welcome.txt文件尚未提交的修改。
git checkout -- welcome.txt
更改一下welcome.txt的时间戳,查看.git/index文件的时间戳
touch welcome.txt
ls --full-time .git/index
文件 .git/index实际上就是一个包含文件索引的目录树,像是一个虚拟的工作区。
在这个虚拟工作区的目录树中,记录了文件名和文件的状态信息(时间戳和文件长度等)。
文件的内容并没有存储在其中,而是保存在Git对象库.git/objects目录中,文件索引建立了
文件和对象库中对象实体之间的对应。
执行git reset HEAD命令时,存储区的目录树会被重写,会被master分支指向的目录树
所替换,但是工作区不受影响。
执行git rm --cached <file>命令时,会直接从暂存器删除文件,工作区则不作出改变。
执行git checkout . 或git checkout -- <file> 命令是,会用暂存区全部的文件或
指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区的改动。
执行git checkout HEAD .或git checkout HEAD <file>命令是,会用HEAD指向的master分支中
的全部或部分文件替换暂存区和工作区中的文件。这个命令也是极具危险性的,因为不但会清除
工作区中未提交的改动,也会清除暂存区中未提交的改动。
对于HEAD(版本库中当前提交)指向的目录树,可以使用Git底层命令ls-tree来查看。
git ls-tree -l HEAD
git clean -fd 命令清除当前工作区中没有加入版本库的文件和目录,
执行git chekout .命令,用暂存区内容刷新工作区。
工作区和暂存区比较
git diff
暂存区和HEAD比较
git diff --cached
工作区和HEAD比较
git diff HEAD
查看分支的改动
git cat-file -t
git cat-file -p
看到工作区和暂存区中没有改动
git status -s -b
-s参数以显示精简输出外,
-b显示出当前工作分支的名称
也可以显示当前的工作分支:
git branch
下面三个指令显示相同的输出:
git log -l HEAD
git log -l master
git log -l refs/heads/master
HEAD、master和refs/heads/master具有相同的指向。
find .git -name HEAD -o -name master