详情参考:
https://www.jianshu.com/p/c2ec5f06cf1a
一、本质
git reset的本质是:移动HEAD以及它所指向的branch
二、参数
三种不同的参数(–hard \soft\mixed):影响的是工作区和缓存区清空与保留
–hard:
参数 | 功能 | 场景 |
---|
–hard | 清空工作区与缓存区 | 放弃目标版本后所有的修改 |
–soft | 保留工作区与缓存区,但是把版本之间的差异存放在缓存区 | 合并多个commit |
–mixed(或缺省) | 保留工作区清空缓存区,把版本之间的差异存放在工作区 | 1、有错误的commit需要修改;2、git reset HEAD清空缓存区 |
三、使用样例
$ git reset --hard HEAD
$ git reset --soft HEAD^
$ git reset --mixed HEAD
$ git reset --hard 1094a
$ git checkout -- readme.txt
$ git reset HEAD readme.txt
$ git checkout -- readme.txt
$ git reset --hard 1094a
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)