关于git的commit提交回退的三种命令模式

本文介绍了Git的reset命令在mixed、soft和hard模式下的区别。mixed模式不删除工作区修改,但将修改移出暂存区;soft模式保留工作区修改且修改保留在暂存区;hard模式则会删除工作区修改,回退到上一版本。此外,还提到了如何修改最近的提交注释、通过版本号恢复以及撤销已add到暂存区的文件的方法。

git reset --mixed HEAD^

使用 git reset HEAD^ 命令默认的就是mixed模式,此命令表示不删除本地工作空间提交的代码,也即保留对工作区的修改,但是修改进入暂存区。

git reset --soft HEAD^

此命令也表示不删除本地工作空间提交的代码,也即保留对工作区的修改,并且修改进入暂存区。

git reset --hard HEAD^

此命令表示删除本地工作空间提交的代码,也即不保留对工作区的修改,工作区完全回退到上个版本的样子。此命令注意慎用。

三者最大区别

前面两个命令会保留自己在本地的修改(纯撤回提交,如果是提交之后发现有的地方修改错误,可使用这两个命令撤回提交,然后只对错误的地方重新修改,最后再重新提交),而最后一个命令会恢复自己在本地的修改到上一个提交版本。

必备技能

1)HEAD^的意思是上一个版本,也可以写成HEAD~1,如果你进行了2次commit,都想撤回的话,可以使用HEAD~2,以此类推。
2)如果是commit注释写错了,只是想改一下注释,只需要执行命令行:git commit --amend。此时会进入默认Vim编辑器,修改完之后保存即可。
3)浪子回头再回头。意思是我撤回commit后,我又后悔了,我不想撤回了…。此时我们可以通过版本号来回退,先使用 git reflog 命令来获取版本号,再使用 git reset --hard 版本号 命令来恢复。
4)git reset . 表示撤销已经add到暂存区的文件。
5)修改最新一次push的注释,首先使用git commit --amend修改注释(进入后键入i进行修改,然后按esc键,并键入:wq进行保存),然后使用git push --force CAT 分支名称 即可完成修改。其中CAT为远程项目,具体可查看.git/config下的配置

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值