切换到旧提交,同时保证当前修改不丢失

在 Git 中,可以通过以下几种方式切换到之前的提交,同时保留当前的提交(即不丢失工作进度):

1. 使用 git checkout 创建临时分离头指针(推荐用于查看)

bash 复制代码
git checkout <commit-hash>

这会让你进入"分离头指针"状态,你可以查看旧代码。要返回最新提交:

bash 复制代码
git checkout <原来的分支名>

2. 使用 git branch 创建新分支(最安全)

bash 复制代码
git branch temp-branch <commit-hash>  # 创建临时分支指向旧提交
git checkout temp-branch              # 切换到临时分支

这样你的原分支和新提交都完好保存,可以在临时分支上操作。

3. 使用 git stash 暂存当前修改(修改未提交)

bash 复制代码
git stash          # 保存当前工作
git checkout <commit-hash>  # 切换到旧提交
# 查看或操作后...
git checkout -     # 回到原分支
git stash pop      # 恢复暂存的修改

4. 使用 git reset --soft(可逆操作)

如果想在当前分支"回退"到旧提交但保留所有更改在暂存区:

bash 复制代码
git reset --soft <commit-hash>

之后可以用 git reset ORIG_HEAD 撤销这次回退。

注意事项:

  • 所有方法都不会丢弃提交,只要提交还在 reflog 中(默认保留90天)
  • 要永久丢弃提交需要使用 git reset --hardgit push -f(慎用)
  • 推荐优先使用创建新分支的方式,这是最安全的选择

可以通过 git reflog 查看所有历史操作记录,找回"丢失"的提交。

相关推荐
SStone_TJ12 小时前
【常用的git命令】
git
没有鸡汤吃不下饭13 小时前
Git将某个分支合并到开发(dev)、测试(test)后突然想撤销该分支的功能,怎么处理?
前端·git·github
康一夏13 小时前
git fatal:Server aborted the SSL handshake
git·网络协议·ssl
Vio7251 天前
在IntelliJ IDEA中使用Git
git
Net_Walke1 天前
git 的常用命令
git·物联网·github·iot
L X..1 天前
Git 无法访问 GitHub(Recv failure: Connection was reset)问题解决教程
git·github
建群新人小猿2 天前
客户标签自动管理:标签自动化运营,画像持久保鲜
android·java·大数据·前端·git
来一颗砂糖橘2 天前
Git 进阶指南:深入掌握 git log 查看提交历史
git·版本控制·开发技巧
六点半8882 天前
【Git】远程操作 + 给命令配置别名 + 标签管理
git
虫师c2 天前
GitOps实战:ArgoCD+Tekton打造云原生CI/CD流水线
git·ci/cd·云原生·kubernetes·argocd·tekton