git reset HEAD 与 git reset --hard HEAD的区别
git reset HEAD 是将咱暂存区和HEAD的提交保持一致
git reset --hard HEAD 是将工作区、暂存取和HEAD保持一致
测试 git reset HEAD
1. 创建一个readme.md 的文件
data:image/s3,"s3://crabby-images/e0094/e0094ab8fa485738f081b4d0b2e10d19f5d520cd" alt=""
2 创建一个commit 执行以下命令
git add -A
git commit -m "create readme.md test file"
查看提交
git log --all --graph --oneline
data:image/s3,"s3://crabby-images/027cf/027cfaffbcb8285bc1413cdb63b8cb48bd1f5361" alt=""
3 添加暂存取的文本
data:image/s3,"s3://crabby-images/b652e/b652e8d1249177baf43c6d945712575d92d9bf19" alt=""
执行命令,保持到暂存取
git add -A
执行命令,比较暂存取和HEAD的区别
git diff --cached
data:image/s3,"s3://crabby-images/465e3/465e3db7162bdb2ac5c7ecdc774744ca4c69fb80" alt=""
4 添加工作区的的内容
data:image/s3,"s3://crabby-images/f6f8b/f6f8b5d693e2e0bd6e3ee7465d6dc0d4dbb55eb3" alt=""
执行命令,比较工作区和暂存取的不同
git diff
data:image/s3,"s3://crabby-images/f3898/f3898029ceb90b93e81acd80de6db4f369907810" alt=""
5 执行命令
git reset HEAD
data:image/s3,"s3://crabby-images/ab6cf/ab6cfbc61f31dd660298280775690a953eb40952" alt=""
比较工作区和暂存区的内容
执行命令
git diif
data:image/s3,"s3://crabby-images/bd685/bd6853a1ebd0243c3bc5b85e2e35ca2684e086cc" alt=""
比较暂存取和HEAD的内容
执行命令
git diff --cached
data:image/s3,"s3://crabby-images/d1215/d1215a633b0e19b1036736e6d70e5583baee1235" alt=""
发现暂区和HEAD没有区别
说明 git reset HEAD 会把暂存区恢复成HEAD
6
执行命令
git add -A
添加到暂存区
执行
git diff --cached
data:image/s3,"s3://crabby-images/16bb8/16bb82018a0fd7b10f3722c19bad2c493e5987df" alt=""
发现暂存区添加了两行内容
7
工作区添加一行文字
data:image/s3,"s3://crabby-images/dc195/dc1956ea07e793e04ffe2beb712aad4e70f0fcf7" alt=""
执行
git reset --hard HEAD
data:image/s3,"s3://crabby-images/6f882/6f882b4d121e6758bc0f6ce78347c8fbafb4ae26" alt=""
执行
git diff
git diff --cached
发现工作区、暂存区和HEAD没有区别
data:image/s3,"s3://crabby-images/fa2be/fa2be2ea10e66948bb9afaf5a312f70506acd533" alt=""
说明执行 git reset --hard HEAD 命令 会将工作区和暂存区恢复成HEAD