使用git回退代码

如果你不小心使用 git commit -m 提交了代码,可以通过以下几种方式回退:

1. 使用 git reset 回退提交

软回退(推荐)- 保留工作区和暂存区的更改

bash 复制代码
git reset --soft HEAD~1

这会将最近一次提交撤销,但保留你所有的更改在暂存区中。

混合回退 - 保留工作区更改,但清空暂存区

bash 复制代码
git reset --mixed HEAD~1
# 或者简写为
git reset HEAD~1

这会撤销提交并将更改放回工作区(未暂存状态)。

硬回退 - 完全删除提交和所有更改(危险操作)

bash 复制代码
git reset --hard HEAD~1

⚠️ 警告:这将永久删除提交和所有相关更改,无法恢复。

2. 使用 git revert 创建反向提交(适用于已推送的提交)

bash 复制代码
git revert HEAD

这会创建一个新的提交来撤销上一次提交的更改,适合已经推送到远程仓库的情况。

3. 修改最后一次提交(如果尚未推送)

如果你只是想修改提交信息或添加遗漏的文件:

bash 复制代码
# 修改提交信息
git commit --amend -m "新的提交信息"

# 或者添加遗漏的文件后修改提交
git add <遗漏的文件>
git commit --amend --no-edit

如何选择合适的方法:

  • 如果提交尚未推送到远程仓库 :使用 git reset
  • 如果提交已经推送到远程仓库 :使用 git revert
  • 如果只是想修改提交信息或内容 :使用 git commit --amend

建议先使用 git log 查看提交历史,确认当前状态后再选择合适的回退方式。

相关推荐
Rabbit_QL2 小时前
【Git 报错处理】`remote origin already exists` 是什么意思?
git
陈佬昔没带相机5 小时前
GitHub clone 不动、pip 卡住、brew 转圈?一份指南搞定
git·npm
CoovallyAIHub8 小时前
15K Star中文首发!$5部署一个会自我进化的私人Agent——NousResearch开源Hermes Agent
git·架构·github
无限进步_9 小时前
【C++】巧用静态变量与构造函数:一种非常规的求和实现
开发语言·c++·git·算法·leetcode·github·visual studio
降临-max10 小时前
Git 协同开发与冲突解决
笔记·git
高志小鹏鹏11 小时前
告别“修复 bug”:让别人一眼看懂你的 Commit
git·github·代码规范
Rabbit_QL15 小时前
【Git基础】03——Git 撤销与回退:改错了怎么办
大数据·git·elasticsearch
无限进步_15 小时前
【C++&string】寻找字符串中第一个唯一字符:两种经典解法详解
开发语言·c++·git·算法·github·哈希算法·visual studio
HashFlag15 小时前
Git经典锁报错问题
linux·windows·git·mac
木下~learning15 小时前
零基础Git入门:Linux+Gitee实战指南
linux·git·gitee·github·虚拟机·版本控制·ubunt