【Git的基本操作】版本回退 | 撤销修改的三种情况 | 删除文件

目录

5.版本回退

5.1选项hard&后悔药

5.2后悔药&commit id

5.3版本回退的原理

6.撤销修改

6.1情况一

6.2情况二

6.3情况三

​7.删除文件


Git重要能力之一马,版本回退功能。Git是版本控制系统,能够管理文件历史版本。本篇以ReadMe文件为例。

  • 版本回退 是回到某一次提交或者回退操作的时候版本 (用提交记录的commit id即可)
  • 版本撤销 是直接定位某个文件需要撤销的内容。

5.版本回退

版本回退命令:git reset

版本回退命令本质是:将版本库里面的内容回退的。

git reset也存在多个选项。

git reset 命令语法格式为:

git reset [--soft | --mixed | --hard] [HEAD]  你想要回退到的版本的commit id(提交记录)

  • Git reset 只是回退版本库(本地仓库)中的内容。关于工作区和暂存区的内容回退,需要git reset --选项 后面的选项来决定。
  • 版本回退是回退一次 add或者commit 操作,不是一个仅仅某个文件的版本。(这次提交的所有文件的版本都不算)
  • --soft:只回退版本库中的内容
  • --mixed:会回退版本库和暂存区的内容(默认选项)

  • --hard:会回退版本库和暂存区和工作区的内容。(注意❗hard要慎用,一旦使用hard选项,版本库/暂存区/工作区所有的内容都回退到上一个版本。如果文件少,代码少,可以用commit id找回来;如果文件过大,操作频繁,很可能导致丢失一些新开放的代码

  • git log --pretty=oneline 或者 git log 用来查看 每次提交的记录

  • git reset 除了以上的版本回退的操作,还可以将文件回退到当前版本HEAD

  • HEAD当前版本意思就是工作区和暂存区的内容版本和版本库中一致。(看选项)


背景☞回退操作

ReadMe文件原本只有hello linux

ReadMe文件修改之后增加了一行aaaaaaaaaa

git reset [--soft | --mixed | --hard] [HEAD]
git reset --soft //仅工作区的内容
git reset --mixed //是工作区和暂存区的内容——默认选项
git reset --hard //是工作区和暂存区和版本库的内容——慎用
git reset HRAD //(HEAD就是表示回退到当前版本,不需要选项,因为选项是默认选项)//就是工作区和暂存区的内容一起回到版本库内容一致
git reset HRAD^  //回退到上一个版本
git reset HRAD^^  //回退到上上个版本
//后面都要接commit id或者文件名

5.1选项hard&后悔药

git reset --hard 7f0ea7a49fc354e7f07696609b0c9e8ec261d0b8

用户此刻后悔了,能不能撤销刚刚的操作。

当然可以,刚刚已经答应了最新的commit id,我们知道我们原来版本(回退之前)的commit id,所以还可以回退到原来的文件版本。因为我们可以找到commit id,且并没有将modify的ReadMe的commit id清除掉.

5.2后悔药&commit id

 git reflog :用来记录每一次的提交命令

每一次提交或者是回退操作都有各自操作对应commit id

我们照样也可以使用一部分的commit id来回退

以上的前提是我们能找到commit id,在开发的过程中,我们会进行很多次的git操作,会把commit id冲刷掉,找不到。

5.3版本回退的原理

版本回退的速度是非常快的,版本回退的速度为什么快呢❓

只需要修改的master的指向(指针)

6.撤销修改

git checkout  -- 需要撤销的文件名

  • 将工作区的文件回到醉经一次的add或者commit时的一个状态
  • 注意:必须加上-- 这两根横线,不然就是另外一层含义

背景☞撤销操作

版本12:hello linux aaaaaaaaaaaa

版本3:xxxxx code(需要撤销这行代码)

6.1情况一

情况一:只在工作区的ReadMe文件修改了内容

解决办法:

  • 手动撤销——不推荐,容易出错    
  • git checkout --[filename] --推荐

6.2情况二

情况二:在工作区的ReadMe文件修改了内容并且add到了暂存区。

解决办法:

  • 回退命令 git reset HEAD (默认选项--mixed)暂存区回退到当前版本,回到撤销情况一   
  • 使用git checkout 撤销命令。或者是直接git reset --hard HEAD 一步到位

6.3情况三

情况三:在工作区的ReadMe文件修改了内容并且add到了暂存区和commit提交到了版本库中。

  • 前提时:commit 之后没有push
  • 撤销的目的是 不影响远程仓库的代码
  • 解释:我们使用操作只能截止到commit操作,而不能使用Push操作。有个这个大的前提,我们的撤销才算有效。含义:将来在公司运行一些代码,是运行的/跑的 远程仓库的代码。(所以我们主要是围绕远程仓库来玩)撤销主要就是撤销我们本地一些错误的,不好的代码。修改完才能推送到远程仓库。
  • 远程仓库:暂时不用理解。
  • 工作区——add——>暂存区——>commit——>版本库——>Push——>远程仓库
  • 因为上面两种撤销情况我们都不需要考虑,都没有commit到版本库中,不可能到远程仓库。这种情况,版本库中有了,我们不知道,远程仓库里是否被Push了。所以前提条件就是,远程仓库没有被Push,这个撤销操作才算有效。

解决办法:

  • 前提条件:commit 之后没有push    
  • 使用git reset --hard commit id
  • 一步一步回到撤销情况二 撤销情况一 再用git checkout

7.删除文件

删除一个已经更新到版本库中的文件(两种做法) 

//做法1
rm file
git add file
git commit -m "delete file"//做法2
git rm file //把工作区和暂存区的文件一步到位删除
git commit -m "delete file"

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

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

相关文章

神器!3个免费PPT成品网站推荐+3款AIPPT工具盘点!

熬夜加班做PPT却没有头绪?别再自己憋着想了!现在凡事主打一个“抄作业”,想做ppt却没想法,可以去到ppt成品网站搜集PPT模板,或是使用时下流行的AI生成PPT工具,只需输入PPT主题,即可快速生成一份…

全网最详细的CRC讲解即计算

CRC 循环冗余码(Cyclic Redundancy Code, CRC)是一种用于校验通信链路上数字传输准确性的计算方法(通过某种数学运算来建立数据位和校验位(CRC)的约定关系的)。它是利用除法以及余数的原理来作错误侦测。 发送方: 使用…

客户关系管理怎么做?这4个工具一定要会用!

在商海浮沉中,每一位企业家和销售经理都深知,客户是企业生存与发展的基石。但如何有效管理这些宝贵的资源,让每一次互动都成为加深关系、促进成交的契机,却是一门艺术加科学的结合体。今天,咱们就来聊聊客户关系管理&a…

3SRB5016-ASEMI逆变箱专用3SRB5016

编辑:ll 3SRB5016-ASEMI逆变箱专用3SRB5016 型号:3SRB5016 品牌:ASEMI 封装:SGBJ-5 批号:2024 现货:50000 最大重复峰值反向电压:1600V 最大正向平均整流电流(Vdss):50A 功…

CNN -1 神经网络-概述

CNN -1 神经网络-概述 一:芯片科技发展介绍了解1> 芯片科技发展趋势2> 芯片使用领域3> 芯片介绍1. 神经网络芯片2. 神经网络处理单元NPU(Neural Processing Unit)二:神经网络1> 什么是神经网络2> 神经元3> 人工神经网络三:卷积神经网络(CNN)入门讲解一…

【Spring】springSecurity使用

一、基本配置 1. 引入依赖 在Spring Boot项目中&#xff0c;使用Spring Security首先需要引入相应的依赖。在pom.xml中添加spring-boot-starter-security依赖&#xff1a; <dependency> <groupId>org.springframework.boot</groupId> <artifactId>…

Kodcloud可道云安装与一键发布上线实现远程访问详细教程

文章目录 1.前言2. Kodcloud网站搭建2.1. Kodcloud下载和安装2.2 Kodcloud网页测试 3. cpolar内网穿透的安装和注册4. 本地网页发布4.1 Cpolar云端设置4.2 Cpolar本地设置 5. 公网访问测试6.结语 1.前言 本文主要为大家介绍一款国人自研的在线Web文件管理器可道云&#xff0c;…

唐刘:当 SaaS 爱上 TiDB(一)- 行业挑战与 TiDB 的应对之道

导读 在 TiDB 8.1 发布后&#xff0c;TiDB 展现了强大的支持 SaaS 业务的能力&#xff0c;成为 SaaS 业务数据库的优先选择之一。 本文为“当 SaaS 爱上 TiDB”系列文章的第一篇&#xff0c;系列文章将从技术原理和真实用户体验两个角度深入探讨 TiDB 在 SaaS 业务中的表现&a…

qt gridlayout 应用举例

Qt的GridLayout是一种非常有用的布局管理器&#xff0c;它允许你在一个网格中放置控件&#xff0c;这样你就可以创建出结构清晰、布局整齐的用户界面。下面是一个使用GridLayout的简单例子&#xff0c;展示了如何在一个窗口中放置几个按钮。 #include <QApplication> …

太速科技-3U VPX飞腾处理器刀片计算机

3U VPX飞腾处理器刀片计算机 一 、产品概述 该产品是一款基于国产飞腾FT2000 4核或腾锐D2000 8核的高性能3U VPX刀片式计算机。产品提供了4个x4 PCIe 3.0总线接口&#xff0c;同时可配置为1个x16或2个x8 PCIe3.0接口&#xff0c;因此具有很强的扩展性&#xff0c;极大…

agents 分类

一、分类 自动agent、半自动agent、领域、自定义sop和支持人为干预的agent。 先泼个冷水&#xff0c;目前这些agent项目都是实验品&#xff0c;发展还没有做知识库问答相关开源项目那么成熟&#xff0c; 二、全自动agent autoGPT、loopGPT、babyAGI 全自动agent就是人类不可…

sizeof()

一、题目 *struct T { char a; int *d; int b; int c:16; double e; }; T *p; 在64位系统以及64位编译器下&#xff0c;以下描述正确的是 A: sizeof 24 B: sizeof(p) 24 C: sizeof(p->a) 1 D: sizeof(p->e) 4 二、解析 p是一个指针&#xff0c;指针在32位机器上是…

GEE数据集——全球Ookla 5G 基站地图数据(Ookla 5G Map Data)

Ookla 5G Map Data Ookla 5G 地图数据 Ookla 5G Map™ 于 2019 年 5 月推出,旨在全面展示 5G 技术在全球的扩展情况。在推出之初,该地图突出显示了 17 个国家的 300 项部署,说明了这一变革性技术的初步推广情况。随着时间的推移,该地图已大幅增长,现在包含了来自 142 个…

实例演示Kafka-Stream消息流式处理流程及原理

以下结合案例&#xff1a;统计消息中单词出现次数&#xff0c;来测试并说明kafka消息流式处理的执行流程 Maven依赖 <dependencies><dependency><groupId>org.apache.kafka</groupId><artifactId>kafka-streams</artifactId><exclusio…

Java中的LinkedList(链表)(如果想知道Java中有关LinkedList的知识点,那么只看这一篇就足够了!)

前言&#xff1a;在Java编程语言中&#xff0c;Java集合框架提供了一组丰富的数据结构&#xff0c;以满足各种应用需求。其中&#xff0c;LinkedList作为一种常用的数据结构&#xff0c;具有独特的优势和广泛的应用场景。 ✨✨✨这里是秋刀鱼不做梦的BLOG ✨✨✨想要了解更多内…

linux radix-tree 基数树实现详解

radix tree&#xff0c;又称做基数树&#xff0c;是一种适合于构建key(index)与value(item)相关联的数据结构。内核中使用非常广泛。本文主要聚焦linux内核基数树的代码实现,大量注释过的代码。 radix-tree组织结构如下: 1、数据结构 /** The bottom two bits of the slot de…

如何通过JSON-RPC向以太坊链发送签名交易数据?

概述 在以太坊开发当中,通过web3.js、ethers.js等提供的API方法,都可以完成与以太坊的转账交易。那么如何通过以太坊JSON-RPC与以太坊进行交易呢? 在以太坊的JSON-RPC当中,有eth_sendRawTransaction这个方法,可以向以太坊网络提交预签名的交易广播。 curl https://main…

IDEA阿里云OSS实现文件上传·解决苍穹外卖图片回显

简单交代配置阿里云OSS的思路 1. 首先去阿里云开通一个OSS服务&#xff0c;配置好一个自己的Bucket 2. 在IDEA配置Bucket 3. 拷贝官网的OSS工具类代码 package com.sky.utils;import com.aliyun.oss.ClientException; import com.aliyun.oss.OSS; import com.aliyun.oss.OSS…

同三维T80001编码器(带屏)系列视频使用操作说明书:高清HDMI编码器,高清SDI编码器,4K超清HDMI编码器,双路4K超高清编码器

同三维T80001编码器&#xff08;带屏&#xff09;系列视频使用操作说明书&#xff1a;高清HDMI编码器&#xff0c;高清SDI编码器&#xff0c;4K超清HDMI编码器&#xff0c;双路4K超高清编码器 同三维T80001编码器&#xff08;带屏&#xff09;系列视频使用操作说明书&#xff1…

【C语言】printf、fprintf、sprintf,scanf、fscanf、sscanf的区别

目录 前言 printf、fprintf、sprintf printf fprintf sprintf scanf、fscanf、sscanf scanf fscanf sscanf 前言 这几个函数曾出现在面试中&#xff0c;因为函数名都差不多&#xff0c;所以很让人迷惑啊~ 下面我们逐个分析。 printf、fprintf、sprintf 这三个函数的主…