git 指定版本回退、临时保存 等操作

查看近20条提交记录

复制代码
git log --oneline -20

场景一:本地回退,不影响远端(最安全)

bash 复制代码
# 只是想本地代码回上一次提交后
git reset --hard HEAD~1
# 等价于:
git reset --hard 88c8975

注意:--hard 会丢弃未提交的修改

场景二:本地 + 远端都回退(你是唯一开发 / 已确认)

bash 复制代码
git reset --hard 88c8975
git push -f origin master

注意: 6dda5f4 会在远端历史中被"抹掉",如果别人已经拉了 6dda5f4,会造成历史冲突

场景三:不改历史,用"反向提交"撤销(最规范)

bash 复制代码
git revert 6d308ce

结果:新增一个 commit,撤销 6dda5f4 的所有修改

日志最新的那条会变成类似:xxxxx Revert

场景四:改动要保留,但不想现在提交

bash 复制代码
git stash
# 以后想恢复:
git stash pop

"防翻车"小技巧(很实用),回退前先打个 tag

tag = 给某个提交打一个"书签 / 保险点",等价于在 Git 历史里说:"我给 6d308ce 这个状态存个档"

bash 复制代码
git tag backup-6dda5f4
# 万一后悔了:
git reset --hard backup-6dda5f4

给你一套「不翻车标准流程」(建议你以后照抄)

bash 复制代码
# 1. 看状态
git status

# 2. 如果有改动,先存
git stash

# 3. 打保险 tag
git tag backup-before-reset

# 4. 回退
git reset --hard HEAD~1

恢复方案:

bash 复制代码
# 恢复回退点
git reset --hard backup-before-reset

# 恢复改动
git stash pop

总结:

reset = 改历史(危险)
revert = 不改历史(安全)
tag = 后悔药
stash = 临时抽屉

相关推荐
李少兄4 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
先跑起来再说10 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
承渊政道13 小时前
Linux系统学习【Linux系统的进度条实现、版本控制器git和调试器gdb介绍】
linux·开发语言·笔记·git·学习·gitee
Doro再努力13 小时前
【Linux操作系统12】Git版本控制与GDB调试:从入门到实践
linux·运维·服务器·git·vim
摇滚侠16 小时前
MAC IDEA GIT 提交区显示了几个不存在的目录
git·idea
城东17 小时前
Git使用[远程仓库远端的head比本地和提交的head旧,其他人拉不到最新代码]
git·head·远程仓库远端·比本地和提交的head旧·其他人拉不到最新代码
何中应1 天前
使用SSH地址拉取远程仓库代码报下面的错误
git
何中应1 天前
Git本地仓库命令补充
git
sun0077001 天前
执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?
git
胖虎11 天前
Git 一个本地仓库同时推送到两个远程仓库(详细教程)
git·多远程仓库·双远程仓库·git双远程·git备份