一起学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后,之前提交的更改会从暂存区中移除,但是这些更改仍然保留在工作目录中,你可以重新进行暂存和提交。

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

相关推荐
深海鱼在掘金1 小时前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc21 小时前
关于Git Flow
git
蜜獾云21 小时前
在Git中配置用户名和密码
git
scx_link1 天前
通过git bash在本地创建分支,并推送到远程仓库中
开发语言·git·bash
南大白1 天前
IntelliJ IDEA 运行时的 JVM 本地内存溢出崩溃
git
码农小旋风1 天前
Claude Code 基础用法大全:对话、分析、修改、测试、Git 和工作流
人工智能·git·chatgpt·claude
南大白1 天前
Git 撤回提交完整方案
git
像风一样的男人@1 天前
python --实现代理服务器
git·ui
sbjdhjd1 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
码云数智-大飞1 天前
Go Channel 详解:并发通信的正确姿势
前端·数据库·git