git checout 失误后回溯

一天代码写完一定要走 git add git commit

有时候失误 git checkout xxx 源文件丢失怎么办??

理解:当前完成品代码 切换到上个版本了,完成品代码的信息不在git log内。

cpp 复制代码
查看所有分支的提交历史,包括已经被删除的提交记录。
git reflog 

0663723 (HEAD, origin/master, master) HEAD@{0}: checkout: moving from master to 0663723
0663723 (HEAD, origin/master, master) HEAD@{1}: checkout: moving from b895ee45673f5e4e4d6a778253cd736a43f67d51 to master
b895ee4 HEAD@{2}: commit: 界面美化   **成品代码文件 丢失的文件
0663723 (HEAD, origin/master, master) HEAD@{3}: checkout: moving from master to 0663723fb8293852d83dfe56173d37d555eaaf7b
0663723 (HEAD, origin/master, master) HEAD@{4}: commit: 完善界面 增加日志
3780ba2 HEAD@{5}: commit: 基本界面完成
7751245 HEAD@{6}: commit: 基本界面v2.0 基本排版
6bf13dd HEAD@{7}: commit: 基本界面
539d8e6 HEAD@{8}: commit (initial): 登录模块

git show hash 查看修改文件的记录 确定到完成品代码

找到了后比如 b895ee4 
git checkout b895ee4   //这就回到了完成品代码

git checkout master       //但是主分支不是b895ee4 使用切回去 然后再重新设置。
git reset --hard b895ee4 
git push --force origin master   //推送给远端

总结:主要还是记录一下git方法,由于是新手,有时候不知不觉的就把成品代码文件回溯到之前版本。导致一周工作量白费

相关推荐
卖报的大地主39 分钟前
Learn Claude Code Agent 开发 | 12、目录级隔离:Git Worktree实现多任务并行无冲突
大数据·git·elasticsearch
Amnesia0_043 分钟前
linux中的git和gdb
linux·运维·git
原来是猿1 小时前
Git【多人协作二】
git
小陈工2 小时前
2026年4月1日技术资讯洞察:AI芯片革命、数据库智能化与云原生演进
前端·数据库·人工智能·git·python·云原生·开源
我先去打把游戏先3 小时前
Git 一个本地仓库同时推送到两个远程仓库(私人 GitHub + 公司 Git)保姆级教程
git·vscode·单片机·嵌入式硬件·物联网·学习·github
jian110584 小时前
Mac git生成SSH秘钥
git·macos·ssh
要不枉此行4 小时前
Git 批量拉取所有远程分支到本地(Git Bash + CMD 双版本)
git
李少兄4 小时前
Git远程连接指南:SSH与HTTPS协议详解
git·https·ssh
凉生阿新5 小时前
【React】从零配置 Git Hooks:提交前自动校验与格式化(Vite + React 19)
前端·git·react.js
C++ 老炮儿的技术栈16 小时前
分享一个安全的CString
c语言·c++·windows·git·安全·visual studio