Git Reset 详解:Soft、Mixed、Hard、Keep 选项

这篇具有很好参考价值的文章主要介绍了Git Reset 详解:Soft、Mixed、Hard、Keep 选项。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在 Git 中,git reset 是一个强大的命令,用于移动 HEAD 指针和修改提交历史。它有不同的选项,包括 --soft--mixed--hard--keep,每个选项都有不同的用途和影响。本文将深入解析这些选项的作用和用法。

1. --soft 选项

--soft 选项执行一种“软”重置,它会移动 HEAD 指针到指定的提交,但不会影响工作目录和暂存区。具体步骤如下:

git reset --soft <commit>
  • 不影响工作目录和暂存区: 已修改的文件保留在暂存区,工作目录中的文件也不受影响。
  • 用途: 通常用于取消上一次提交,将更改重新放入暂存区,以便进行修改后再次提交。

2. --mixed 选项

--mixed 选项是 git reset 的默认选项,它执行一种“混合”重置。具体步骤如下:

git reset --mixed <commit>
  • 不影响工作目录: 工作目录中的文件保持不变。
  • 清空暂存区: 暂存区的所有内容都会被清空。
  • 用途: 通常用于取消上一次提交,但保留更改在工作目录中,不放入暂存区。

3. --hard 选项

--hard 选项执行一种“硬”重置,它会彻底清除工作目录和暂存区。具体步骤如下:

git reset --hard <commit>
  • 清除工作目录和暂存区: 工作目录和暂存区的所有内容都会被恢复到指定提交的状态。
  • 慎用: 永久性地丢弃本地的更改,谨慎使用。

4. --keep 选项

--keep 选项保留已提交的内容,但清除未提交的本地更改。具体步骤如下:

git reset --keep <commit>
  • 清空工作目录: 工作目录中的所有文件都会被清空。
  • 保留已提交的内容: 保留指定提交的内容。
  • 用途: 用于保留提交内容但清空未提交的本地更改。

总结

  • Soft: 保留所有更改并撤销提交。
  • Mixed: 保留工作目录但清空暂存区。
  • Hard: 彻底丢弃本地更改,恢复到指定提交状态。
  • Keep: 保留提交内容但清空未提交的本地更改。

注意: 默认情况下,不带任何选项的 git reset 等同于 git reset --mixed文章来源地址https://www.toymoban.com/news/detail-836196.html

到了这里,关于Git Reset 详解:Soft、Mixed、Hard、Keep 选项的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • idea中代码git的版本穿梭&Git Rest三种模式详解(soft,mixed,hard)

    使用Git进行版本控制开发时难免会遇到回顾的情况,这里来解释下该如何正确的回滚 idea 使用 git 切换版本博文链接 本地回滚就很简单,只是要撤销 commit 信息即可。可以直接使用 Reset HEAD进行回滚。 HEAD^ 是还原到上一个版本,HEAD^^ 是还原到上上一个版本。 Reset Type 有三种:

    2024年02月05日
    浏览(42)
  • git reset --soft 用法

    git reset --soft 是 Git 命令中的一个选项,它用于取消之前的提交,并将取消的更改保留在暂存区。这允许您重新组织提交历史或将更改合并到一个新的提交中,而不影响暂存区和工作目录中的更改。 这个命令的语法是: 其中 commit 是您要取消的提交的引用(可以是提交哈希、

    2024年02月11日
    浏览(42)
  • 解决git reset --soft HEAD^撤销commit时报错

    今天在使用git回退功能的时候,遇到以下错误: 问题: 在进行完commit后,想要撤销该commit,于是使用了git reset --soft HEAD^命令,但是出现如下报错: 查了下原因可能有两种: 因为cmd控制台中换行符默认是’^ \\\',而不是 ,所以^符号被git编译为换行符了,解决方案: 该仓库到

    2024年02月11日
    浏览(53)
  • 解决git reset --soft HEAD^撤销commit时报错:fatal: ambiguous argument ‘HEAD^‘.....

    问题: 在进行完commit后,想要撤销该commit,于是使用了 git reset --soft HEAD^ 命令,但是出现如下报错: 寻找过程: 在尝试了国内的一些博客提供的方法后,仍然无法解决问题。于是去Stack overflow上查了一下,找到了方法。 原因猜想: 在Stack overflow上,有人和我遇到了同样的问

    2024年02月11日
    浏览(48)
  • 【已解决】git 撤销上次提交后修改文件再次提交 触发:Cannot do a soft reset in the middle of a merge

    记录一次 git 操作 git 撤销上次提交后修改文件,然后同步触发以下命令及报错(报错来源与git输出面板) 同步包含两步: pull push git pull 此次合并未处理(变更记录未覆盖任何冲突处) git pull 此次合并未处理干净(变更记录未完全覆盖所有冲突处) git pull 此次拉取前未提交

    2024年02月15日
    浏览(54)
  • git reset --hard详解

    提示:这里简述项目相关背景: 在企业中使用git进行版本回退时,经常会用到 git reset命令,但有时使用参数并不相同: git reset 节点id git reset --hard 节点id (1)当加参数–hard时 此时不但将本地的HEAD指针指向了上一个版本,重置了暂存区的内容,而且还修改重置了本地工作区

    2024年02月11日
    浏览(48)
  • (详解踩坑)GIT版本回滚git stash、git reset、git reset --hard、git revert

    目录 背景 一、(git log、git reflog)查看git提交日志及命令历史 1.1 git log(提交日志)  1.2 git reflog(命令历史) 二、git reset(回退到指定的版本,并且保留更改) 2.1 回退到指定版本 2.2 快捷回退上一版本 三、git reset --hard(回退到指定版本,不保留更改) 四、git revert(回退

    2024年02月12日
    浏览(52)
  • cenos 安装es Linux中soft nproc 、soft nofile和hard nproc以及hard nofile配置

     下载:Download Elasticsearch | Elastic tar -zxvf xxx ./bin/elasticsearch 启动es  安装官方文档;Install Elasticsearch from archive on Linux or MacOS | Elasticsearch Guide [8.3] | Elastic bootstrap check failure [1] of [3]: max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535] bootstrap check failure [2]

    2024年02月07日
    浏览(34)
  • cenos 安装es Linux中soft nproc 、soft nofile和hard nproc以及hard nofile配置

     下载:Download Elasticsearch | Elastic tar -zxvf xxx ./bin/elasticsearch 启动es  安装官方文档;Install Elasticsearch from archive on Linux or MacOS | Elasticsearch Guide [8.3] | Elastic bootstrap check failure [1] of [3]: max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535] bootstrap check failure [2]

    2023年04月09日
    浏览(36)
  • soft ip与hard ip

    ip分soft和hard两种,soft就是纯代码,买过来要自己综合自己pr。hard ip如mem和analog与工艺有关。 mem的lib和lef是memory compiler产生的,基于bitcell,是foundry给的。 我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 知识星球入口  

    2024年02月14日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包