Git 之reflog回滚操作失误

news2025/1/22 19:06:38

前言

以前只知道有git log命令,并不知道有git reflog。今天一个偶然的机会,我不小心把自己前两天写的代码给整丢了,如果时几个小时的代码,我重新写一遍就算了,但是这次不一样,这次是非常重大的修改,如果要重写,至少要1-2天,时间上也不允许我这么做,好在最后是git reflog拯救了我。

我先简单描述下我的代码为什么丢失:先说明我的提交和推送等操作都没有错误,但是前两天不知什么原因,我的代码被切换到了HEAD detached状态下,detached HEAD 指的是HEAD指针没有指向任何的branch,而是指向了一个commit。我一直提交代码持续到今天,一直都没有发现。直到今天才把一个重大功能搞定了,正当我准备把代码都推送下,然后松一口气,喝杯咖啡休息会儿时,发现代码怎么不在master分支,于是我就没多想双击了一下master分支,于是代码顺利被切换到了master分支,但是之前提交的代码和记录都没了,虽然IDE还可以撤回近期修改的几行代码,但是这几天修改的代码,预制体,场景,全部丢失,我瞬间慌了,好在最后找到了一个和我有相同遭遇的博主,拯救了我。

git reflog

reflog:全称:reference logs,是在本地仓库,记录了 当“分支或其他引用”有更新时的 所有 提交记录
我们通过对比git log来详细解释下 git reflog到底是什么意思
git log 是显示沿着当前分支指针,递归查找父节点的父节点…的日志
git reflog 不是针对当前分支的。他和分支无关,是Head所指向的一个顺序的提交列表,甚至它不是repo的一部分,它单独存储而且不包含在pushes,fetches或者clones里面,它纯属是本地的。
所以,reflog可以很好的帮助我们恢复我们的所有的误操作。

修复过程

先展示我的误操作记录,从下往上看,大家可以发现本来我在master分支正常提交,但是不知道为啥,突然提交跑到Head上面了,这就是属于detached HEAD状态了。
在这里插入图片描述

下面我们展示如何修复

1.git reflog
执行git reflog,找到Head detached的id为 d4eb12002072df5f40e194d3b8cf3603f02b4c63,
2.git checkout d4eb1200
检出detached的记录

此时我们就会发现代码已经找回了,接下来我们就赶快把detached的代码合并到master就可以了。

结束

好在有惊无险,又学到一招,不得不感叹:学无止境呀,git真的是一个博大精深好的工具。
希望这篇文章可以对你有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/196216.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

openfeign集成sentinel实现服务降级

openfeign集成sentinel实现服务降级使用openfeign调用服务(不含sentinel)代码测试openfeign集成sentinel实现服务降级引入sentinel相关环境编写FeignClient注解接口的实现类在服务提供者中,认为添加异常代码,以供测试 / 或者不启动…

SpringBean的生命周期

下文要讲的均是spring的默认作用域singleton的bean的生命周期,对spring作用域不了解的可以 https://blog.csdn.net/hlzdbk/article/details/128811271?spm1001.2014.3001.5502 什么是SpringBean的生命周期 springBean的生命周期,指的是spring里一个be…

Python爬虫以及数据可视化分析之某站热搜排行榜信息爬取分析

目录前言一,确定目标二,发送请求三, 解析数据四, 保存数据pyecharts进行可视化“某站”数据排名前10视频类型“某站”标题标签可视化“某站”喜欢视频分类概况总结前言 本项目将会对“某站”热搜排行的数据进行网页信息爬取以及数据可视化分析 本教程仅…

数据结构:栈的学习

作者:爱塔居 专栏:数据结构 作者简介:大三学生,希望跟大家一起进步 目录 一、栈 1.1 概念 1.2 栈的使用 1.3 示例 二、栈的应用场景 2.1 改变元素的序列 2.2 逆波兰表达式求值 2.3 括号匹配 2.4 栈的压入、弹出序列 一、栈…

upstream sent duplicate header line: “Transfer-Encoding: chunked“

实际情景: 公司项目有一个下载文件的功能,没有经过Nginx代理之前,好好的,正常下载; 加入了Nginx代理之后,过Nginx访问就会有 err_empty_response 这个错误; 搞了半天,nginx.conf加入…

第一章 linux概述

第一章 Linux概述 1、为什么要使用Linux Linux内核最初只是由芬兰人林纳斯托瓦兹(Linus Torvalds)在赫尔辛基大学上学时出于个人爱好而编写的。 Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支…

【蓝桥杯_学习_51单片机】矩阵键盘 状态机法

矩阵键盘 一.基础知识 在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式采用逐行或逐列的“扫描”,就可以读出任何位置按键的状态 矩阵键盘和独立按键一样,也需要进行消抖处理! 于此补充一下抖…

c++之基础入门一

一、c的初始化typedef struct student {int age;char name[10];int num; }student;int main() {//在c中可以利用花括号进行初始化struct student student1{12,"zs",123456 };int a 10, b 20;int b{ 20 }, a{ 10 };double c{ 20 };int* p{ nullptr };int arr[10]{ 1…

Day877.数据空洞 -MySQL实战

数据空洞 Hi,我是阿昌,今天学习记录的是关于数据空洞的内容。 数据库占用空间太大,把一个最大的表删掉了一半的数据,怎么表文件的大小还是没变? 一个 InnoDB 表包含两部分,即: 表结构定义数…

我通过 tensorflow 预测了博客的粉丝数

前言:由于最近接触了 tensorflow.js,出于试一下的心态,想通过线性回归预测一下博客的粉丝走向和数量,结果翻车了。虽然场景用错地方,但是整个实战方法用在身高体重等方面的预测还是有可行性,所以就记录下来…

亚马逊云科技助力游戏上云学习心得-增长篇

云服务已经是大势所趋了,通过购置传统服务器来进行应用开发,无法与现代化敏捷的开发方法相结合,对于系统运维的难度也大大增加,而云服务的弹性伸缩、动态计费可以很好地帮助中小企业实现快速应用开发,使得产品的价值最…

LeetCode题目笔记——1337. 矩阵中战斗力最弱的 K 行

文章目录题目描述题目难度——简单方法一:暴力,统计代码/Python方法二:优化代码总结彩蛋题目描述 给你一个大小为 m * n 的矩阵 mat,矩阵由若干军人和平民组成,分别用 1 和 0 表示。 请你返回矩阵中战斗力最弱的 k 行…

Dubbo服务方消费方通信案例

文章目录Maven_服务方Maven_服务消费方测试通信使用注册中心自动找服务设置超时时间重试次数单独设置某个方法不可重试处理多版本的问题本地存根策略负载均衡策略Dubbo高可用服务降级服务降级实现方式Maven_服务方 pom文件&#xff0c;注意依赖的版本。 <properties><…

《无线电发射设备管理规定》解读

2022年12月22日&#xff0c;工业和信息化部公布了《无线电发射设备管理规定》&#xff08;工业和信息化部令第57号&#xff0c;以下简称《规定》&#xff09;。为了更好地理解和执行《规定》&#xff0c;工业和信息化部产业政策与法规司负责同志对《规定》进行了解读。 问题一 …

7.卷积神经网络

7.卷积神经网络 目录 从全连接层到卷积图像卷积 互相关运算&#xff08;手撕卷积&#xff09;卷积层图像中目标的边缘检测学习卷积核 填充和步幅 填充Padding步幅stride 多输入多输出通道 多输入通道多输出通道11 卷积层总结 池化层 最大池化层和平均池化层填充和步幅多个通道…

Matlab 与 Excel 文件的交互

事实上&#xff0c;excel可以解决绝大多数的建模问题&#xff0c;只不过&#xff0c;更加复杂。。。而且难以操作。。。其实可以看看excel的 功能还是很多的不过嘛 术业有专攻的 有专攻的多主体 NetLogo仿真 Comsol 。。。Excel 文件写入向量与张量的excel写入xlswrite(<pat…

JTAG 基础和svf specification介绍

参考&#xff1a; https://www.youtube.com/watch?vUuDf3q5aBjM https://zh.m.wikipedia.org/zh-cn/JTAG浅谈dft之boundary scan JTAG: Joint Test Action Group是开发IEEE 1149.1的工作组&#xff0c;1149.1定义了一个测试开发版上芯片的标准。现在变成了芯片的一个最常见…

yolov5增加iou loss,无痛涨点trick

yolo无痛涨点trick&#xff0c;简单实用 先贴一张最近一篇论文的结果 后来的几种iou的消融实验结果在一定程度上要优于CIoU&#xff0c;最新的WIoU暂时还没复现。 本文将在yolov5的基础上增加SIoU&#xff0c;EIoU&#xff0c;Focal-XIoU&#xff08;X为C,D,G,E,S等&#xff09…

使用Kindling 观测 Kubernetes 应用网络连接状态

kindling介绍&#xff1a; Kindling 解决的是&#xff0c;在不入侵应用的前提下&#xff0c;如何观测网络的问题&#xff0c;其功能主要是通过暴露内核事件来实现观测。如果主机内核版本高于 4.14&#xff0c;可以使用 eBPF 模块&#xff1b;如果主机内核是低版本&#xff0c;…

多级缓存实现

多级缓存实现1.什么是多级缓存2.JVM进程缓存2.1.导入案例2.2.初识Caffeine2.3.实现JVM进程缓存2.3.1.需求2.3.2.实现3.Lua语法入门3.1.初识Lua3.1.HelloWorld3.2.变量和循环3.2.1.Lua的数据类型3.2.2.声明变量3.2.3.循环3.3.条件控制、函数3.3.1.函数3.3.2.条件控制3.3.3.案例4…