一起学Git【第五节:git版本回退】

git reset 是 Git 版本控制系统中一个非常强大的命令,它可以用来重置当前分支到指定的状态,即执行撤销操作或者回退至之前的某一版本,他可以回退至之前的某一个提交状态。有三种主要的用法:git reset --soft;git reset --hard;git reset --mixed;

对比如图:

1.git reset --soft <commit>

这个选项会将 HEAD 指向指定的提交(commit),但是暂存区(staged changes)和工作目录(working directory)保持不变。这意味着,如果你之前已经将一些更改添加到了暂存区,这些更改在执行 git reset --soft 之后仍然会被保留在暂存区中,等待下一次提交。

当你想要撤销最后一次提交,但是不想丢失已经暂存的更改时使用该命令。

2.git reset --hard <commit>

这个选项会将 HEAD、暂存区和工作目录都指向指定的提交。这意味着,执行git reset --hard后,所有未提交的更改都会丢失,工作目录中的文件会与最后一次提交的状态一致。

当你想要彻底回到某个特定的提交状态,并且不关心当前工作目录中的任何未提交更改时使用该命令。

3.git reset --mixed <commit>

这是git reset的默认行为。它会将 HEAD 指向指定的提交,并且将暂存区更新为与 HEAD 一致的状态,但是工作目录中的更改不会被影响。这意味着,执行git reset后,之前提交的更改会从暂存区中移除,但是这些更改仍然保留在工作目录中,你可以重新进行暂存和提交。

当你想要撤销最后一次提交,并且不想保留任何暂存的更改时使用该命令。

相关推荐
WebGirl22 分钟前
代码Revert后再次Merge会丢失的问题
git
小皮侠5 小时前
nginx的使用
java·运维·服务器·前端·git·nginx·github
HalukiSan6 小时前
如何提交PR
git·gitlab·github
爱莉希雅&&&17 小时前
shell编程之awk命令详解
linux·服务器·git
baiyu3317 小时前
成为git砖家(12): 看懂git合并分支时冲突提示符
git
wu_aceo1 天前
将本地项目提交到Gitee
git·gitee·提交·本地提交·上传git
随便取个六字1 天前
GIT操作 学习
git·学习
星源~2 天前
tree 命令集成到 Git Bash:可视化目录结构的指南
git·单片机·物联网·嵌入式·项目开发
zhaqonianzhu2 天前
git gerrit安装钩子
git·gerrit
这是个栗子2 天前
【问题解决】VSCode终端中看不到Git-Bash
ide·git·vscode