git 学习(二)

删除设置
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
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值