Git - 记录一次由于少输入了一个命令导致的更改丢失
Git - 记录一次由于少输入了一个参数导致的更改丢失
前言
某晚我激情开发了几个小时,中途没有进行commit存档。准备睡觉时,我想创建一个新的分支并将今晚所有更改提交到新分支上(似乎应该开发时候就创建?)。
然后因为少输入了一个参数,导致被跟踪过的文件的更改全部消失了。
成因
我想创建并切换到api分支:
git checkout -b api
结果一困少输了个-b,变成了:
git checkout api
结果我那晚开发的所有内容恰好都在api这个文件夹下,于是所有的更改都没了。
分析
在执行git checkout命令时,可以将整个仓库还原到一个分支/commit_hash/tag,可以用于恢复一个文件(夹)。
当切换到分支/commit_hash/tag时,正确的命令是git checkout 分支/commit_hash/tag。
- 例如我有一个分支名为
dev,那么我可以使用git checkout dev命令切换到dev分支; - 例如我有一个commit的hash为
9259d713a40e97f97af61a422631b723f5666aa5,那么我可以使用git checkout 9259d713命令切换到这次commit; - 例如我有一个tag名为
v0.1,那么我可以使用git checkout v0.1命令切换到这个tag; - 例如我想创建并切换到
dev分支,那么我可以使用git checkout -b dev命令。
若重名,则优先级分支 > 标签 > commit_hash。
当恢复一个文件(夹)时,正确的命令是git checkout -- 文件(夹)名。
- 例如我有一个文件夹是
Solution,那么我可以通过命令git checkout -- Solution将文件夹Solution恢复到暂存区或版本库。
但是,如果我没有加--,git checkout命令仍然会恢复这个文件夹!
误操
我本来想创建并切换到一个分支api:
git checkout -b api
结果因为困倦忘记输入-b了:
git checkout api
结果此时我还没有api分支,但正好有api文件夹。
git一看,心想,你这命令不规范,想还原一个文件夹但是没有--啊,你应该输成git chcekout -- api,太菜了吧,--都不知道输。还好我git比较聪明,知道你的意思,虽然你没有加--,但我还是帮你把文件夹api给还原了吧。
然后我一个晚上的更改就几乎全被还原了。。。没被还原的,只剩下一些未被跟踪过的文件(新创建的文件)。然后我就在VsCode的时间线里把文件一个一个恢复了一下。。。
竟然,,一丁点提示都没有。
亡羊补牢
早就有人吐槽创建并切换到新分支也是checkout命令,因此从git 2.23开始引入了switch命令。
以后再切换分支时,就使用git switch 分支名;创建并切换到新分支时,就使用git switch -c 分支名好了。
End
另:我的git版本为2.42.0.windows.2。
原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/144929924
相关文章:
Git - 记录一次由于少输入了一个命令导致的更改丢失
Git - 记录一次由于少输入了一个参数导致的更改丢失 前言 某晚我激情开发了几个小时,中途没有进行commit存档。准备睡觉时,我想创建一个新的分支并将今晚所有更改提交到新分支上(似乎应该开发时候就创建?)。 然后因…...
nodeJS下npm和yarn的关系和区别详解
一、命令对应关系 1. 初始化项目 操作npm 命令Yarn 命令初始化项目npm inityarn init跳过提问快速初始化npm init -yyarn init -y 2. 安装依赖 操作npm 命令Yarn 命令安装项目所有依赖npm installyarn install添加依赖npm install <package-name>yarn add <package…...
党员学习交流平台
本文结尾处获取源码。 本文结尾处获取源码。 本文结尾处获取源码。 一、相关技术 后端:Java、JavaWeb / Springboot。前端:Vue、HTML / CSS / Javascript 等。数据库:MySQL 二、相关软件(列出的软件其一均可运行) I…...
HTML5 文件上传(File Upload)详解
HTML5 文件上传(File Upload)详解 HTML5 提供了强大的文件上传功能,允许用户通过网页选择文件并上传到服务器。以下是关于文件上传控件的详细说明。 1. 基本的文件上传控件 使用 <input> 标签的 type"file" 属性可以创建一…...
1.2.1-2部分数据结构的说明02_链表
(1)链表数据结构: 概念: 将列表中相互连接的节点不连续的存储在内存中。与数据不同,我们无法再恒定时间内访问任何元组,如果遍历所有则花费时间与元素总数n成正比。插入和删除1个元素的时间复杂度都是O(n…...
vue elementUI Plus实现拖拽流程图,不引入插件,纯手写实现。
vue elementUI Plus实现拖拽流程图,不引入插件,纯手写实现。 1.设计思路:2.设计细节3.详细代码实现 1.设计思路: 左侧button列表是要拖拽的组件。中间是拖拽后的流程图。右侧是拖拽后的数据列表。 我们拖动左侧组件放入中间的流…...
linux上使用cmake编译的方法
一、hello 例程仅基于一个cpp文件 C文件或工程进行编译时可以使用g指令(需要对每一个程序和源文件分别使用g指令编译),当程序变大时,一个工程文件往往会包含很文件夹和源文件,这时我们需要的编译指令将越来越长&#…...
如何实现el-select多选下拉框中嵌套复选框并加校验不为空功能呢?
如何实现el-select多选下拉框中嵌套复选框并加校验不为空功能呢? 要实现的效果图选择部分品牌但不选选项效果问题概述实现方案el-select组件与el-checkbox组件无缝衔接给form表单加自定义校验规则 要实现的效果图 选择部分品牌但不选选项效果 问题概述 相信大家看到…...
源码理解 UE4中的 FCookStatsManager::FAutoRegisterCallback RegisterCookStats
官方文档:https://dev.epicgames.com/documentation/zh-cn/unreal-engine/API/Runtime/Core/ProfilingDebugging/FCookStatsManager文档中的注释: When a cook a complete that is configured to use stats (ENABLE_COOK_STATS), it will broadcast this…...
Android 根据内存大小显示MTP模式连接PC时的名称
项目有两种内存,要求根据连接电脑拷贝文件时的盘符名称根据内存大小显示不同名称。 frameworks/base/media/java/android/mtp/MtpDatabase.java//mh import android.app.ActivityManager; ...-894,7 896,19 public class MtpDatabase implements AutoCloseable {p…...
不只是mini-react第一节:实现最简单mini-react
项目总结构: ├─ 📁core │ ├─ 📄React.js │ └─ 📄ReactDom.js ├─ 📁node_modules ├─ 📁tests │ └─ 📄createElement.spec.js ├─ 📄App.js ├─ 📄in…...
前端路由layout布局处理以及菜单交互(三)
上篇介绍了前端项目部署以及基本依赖的应用,这次主要对于路由以及布局进行模块化处理 一、 创建layout模块 1、新建src/layout/index.vue <template><el-container class"common-layout"><!-- <el-aside class"aside">&l…...
小结:DNS,HTTP,SMTP,IMAP,FTP,Telnet,TCP,ARP,ICMP
DNS(Domain Name System,域名系统) 是互联网的重要组成部分,它负责将人类易读的域名(如 www.google.com)转换为机器可以识别的 IP 地址(如 142.250.72.206)。这一过程被称为域名解析…...
【C++】P2550 [AHOI2001] 彩票摇奖
博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目描述输入格式:输出格式:输入输出样例: 💯题解思路1. 问题解析 💯我的实现实现逻辑问题分析 💯老…...
并发服务器框架——zinx
zinx框架 Zinx 是一个用 Go 语言编写的高性能、轻量级的 TCP 服务器框架,它被设计为简单、快速且易于使用。Zinx 提供了一系列的功能,包括但不限于连接管理、数据编解码、业务处理、负载均衡等,适用于构建各种 TCP 网络服务,如游戏…...
Unity 中计算射线和平面相交距离的原理
有此方法 能够计算射线和平面是否相交以及射线起点到平面交点的距离 代码分析 var dot Vector3.Dot(ray.direction, plane.normal);计算射线和平面法线的点积,如果大于等于0,则说明射线和平面没有相交,否则,说明射线和平面相交…...
浅谈棋牌游戏开发流程七:反外挂与安全体系——守护游戏公平与玩家体验
一、前言:为什么反外挂与安全这么重要? 对于任何一款线上棋牌游戏而言,公平性和玩家安全都是最重要的核心要素之一。如果游戏环境充斥着各式各样的外挂、作弊方式,不仅会毁坏玩家体验,更会导致游戏生态崩塌、口碑下滑…...
《无力逃脱》V1.0.15.920(59069)官方中文版
艾丹是一名三臂赏金猎人,他必须追捕银河系中最危险、最难以捉摸的割喉者。 有些悬赏是金钱,有些则是有价值的信息。艾丹可以利用这些信息找到让他走上这条路的人,同时也会卷入一个全银河系的阴谋中。 拥有三条手臂可以让你同时对付更多的敌…...
六种主流服务器的选择与使用
网络的运行离不开各种服务器,它们各司其职,为我们提供稳定的网络服务。本文带大家了解6种常见服务器类型。 服务器的六大种类 第一种:Web服务器 Web服务器是互联网的核心。当你打开一个网站,比如百度或淘宝,浏览器会…...
TiDB 升级至高版本提示'mysql.tidb_runaway_watch' doesn't exist 问题处理
作者: asd80703406 原文来源: https://tidb.net/blog/90394c97 背景 近期发现很多人从低版本升级至TiDB v7 或者v8版本,均遇到了tidb-server启动失败,提示报错如下: ["get runaway watch record failed"…...
用陶晶驰串口屏和STM32F407做个简易扫频仪:手把手教你绘制幅频特性曲线
用陶晶驰串口屏和STM32F407打造扫频仪:从硬件搭建到曲线绘制的完整指南 在电子测量领域,扫频仪是分析电路频率响应的基础工具。商用设备往往价格昂贵,而利用陶晶驰串口屏和STM32F407开发板,我们可以构建一个成本低廉但功能完备的简…...
Hugo Paper主题暗黑模式实现原理:深入理解CSS变量与Tailwind配置
Hugo Paper主题暗黑模式实现原理:深入理解CSS变量与Tailwind配置 【免费下载链接】hugo-paper 🪺 A simple, clean, customizable Hugo theme 项目地址: https://gitcode.com/gh_mirrors/hu/hugo-paper Hugo Paper主题是一款简洁、优雅且高度可定…...
手把手教你用DSP28335驱动W5500实现TCP客户端(附完整代码与避坑指南)
DSP28335与W5500以太网通信实战:从硬件连接到稳定数据传输 在工业自动化、远程监控和智能设备领域,嵌入式系统联网已成为刚需。TI的DSP28335凭借其强大的实时处理能力,结合W5500这款硬连线TCP/IP协议栈芯片,能够为设备赋予稳定可靠…...
忍者像素绘卷惊艳效果:云端画坊UI交互+物理反馈+像素质感全流程演示
忍者像素绘卷惊艳效果:云端画坊UI交互物理反馈像素质感全流程演示 1. 像素艺术新纪元:忍者绘卷效果总览 忍者像素绘卷是基于Z-Image-Turbo深度优化的图像生成工作站,它将传统忍者文化与16-Bit复古游戏美学完美融合。这款工具最引人注目的特…...
ANSYS面载荷施加避坑指南:SFL、SFA、SFE命令的区别与SFFRAN转换时机
ANSYS面载荷施加避坑指南:SFL、SFA、SFE命令的区别与SFFRAN转换时机 在ANSYS结构分析中,面载荷的施加是建模过程中最容易出现问题的环节之一。许多工程师虽然掌握了基本命令语法,但在实际应用中常常遇到载荷显示异常、计算结果不符预期等问题…...
bootstrap如何设置响应式导航栏的切换宽度
<p>navbar-expand-* 类决定导航栏水平展开的最小屏幕宽度,如 navbar-expand-md 表示 ≥768px 时展开、小于该值时折叠为汉堡菜单,断点由 Bootstrap 预设且不可自定义像素值。</p>如何用 navbar-expand-* 控制折叠临界点bootstrap 导航栏的“…...
Solon AI v3.13 发布(智能体开发框架,支持 Java8 到 Java26)
Solon AI Solon AI 是一款面向 Java 开发者 的全栈智能体(Agent)应用开发框架。它秉承 Solon 家族一贯的“克制、高效、开放”理念,向上抽象统一接口屏蔽模型差异,向下深度集成向量库、MCP 协议与复杂流控制。 核心理念…...
从零实现MDP:用Python代码拆解马尔可夫决策过程核心算法
1. 马尔可夫决策过程入门指南 第一次接触马尔可夫决策过程(MDP)时,我也被那些数学符号弄得头晕眼花。但当我用Python把它实现出来后,突然就豁然开朗了。MDP本质上是一个用来建模序列决策问题的数学框架,在机器人路径规划、游戏AI等领域都有广…...
Data for AI:取之有度,用之有节!从Harness视角破解Agent应用Token爆炸难题
OpenClaw的流行与Token爆炸OpenClaw的流行最近大家见面免不了都要问一句:你养龙虾了吗?这里的“龙虾”,指的正是近期爆火的开源AI Agent框架OpenClaw。自2025年11月发布以来,OpenClaw在GitHub上已经获得了超过35万星标和超过7万fo…...
从Kaggle数据集到业务策略:如何用Python分析电信客户流失并制定精准留存方案
从Kaggle数据集到业务策略:如何用Python分析电信客户流失并制定精准留存方案 电信行业正面临前所未有的客户流失挑战。根据行业研究,获取一个新客户的成本是保留现有客户的5-25倍。当一位业务负责人拿到客户流失分析报告时,他们最关心的往往不…...
