reset 和 revert
git reset
在 Gitee 上新增仓库 git-demo,并 clone 到本地
bash
git clone https://gitee.com/newarea0/git-demo.git
通过 VSCode 打开项目
新增文件 README.md
3次编辑 README.md
,每次都提交更改,并同步到远程仓库 Gitee
data:image/s3,"s3://crabby-images/aeb8d/aeb8d8552ff86dedb3291c91596a3f10690c463f" alt=""
Preview
data:image/s3,"s3://crabby-images/9a08a/9a08a584e97418ebede351a7b2cb296575457db2" alt=""
Preview
现在要回退到之前版本,如 主要组成
data:image/s3,"s3://crabby-images/de2fa/de2fa810c85b049a81218962f157918678aba7e0" alt=""
Preview
bash
git reset --hard 731473
或者通过 VSCode 操作
data:image/s3,"s3://crabby-images/a5fb1/a5fb18658dfd992a0fad42101c72b14359360e08" alt=""
Preview
data:image/s3,"s3://crabby-images/9a8a2/9a8a2f2b378d159096ade2de6cd1604fb71acbe4" alt=""
Preview
Reset 更改保留在本地
Soft Reset 更改保留在暂存区
Hard Reset 丢弃更改
回退后:
data:image/s3,"s3://crabby-images/a0914/a0914e0d59e4ed6a2535609b4071f7dbb7cb67db" alt=""
Preview
同步到远程
此时本地库HEAD指向的版本比远程库的要旧,使用 git push
会报错
data:image/s3,"s3://crabby-images/48098/4809833f4b01e470cbc15c00b8734b0265f92d3f" alt=""
Preview
改用使用 git push -f
强制推上去
data:image/s3,"s3://crabby-images/477bb/477bb7122efb2ce17157a794c1471f9a44967064" alt=""
Preview
git revert
我们commit了三个版本(版本一、版本二、 版本三),突然发现版本二不行(如:有bug),想要撤销版本二,但又不想影响撤销版本三的提交,就可以用 git revert 命令来反做版本二,生成新的版本四,这个版本四里会保留版本三的东西,但撤销了版本二的东西。