在Git中操作失误,如何撤回

news/2024/10/3 17:59:59 标签: git

在 Git 中,撤回操作可以通过多种方式实现,具体取决于你想要撤回的操作类型(如提交、暂存、修改等)。以下是几种常见场景及其相应的撤回方法:

1. 撤回未暂存的修改

如果你在工作区中进行了更改,但还没有将这些更改暂存(即没有使用 git add),可以使用以下命令撤回这些修改:

git checkout -- <file>
  • 这将恢复指定文件到最后一次提交的状态。

2. 撤回已暂存的修改

如果你已经将更改暂存,但想要撤回这些更改,可以使用:

git reset HEAD <file>
  • 这将把指定文件从暂存区移除,但保留工作区中的更改。你可以继续编辑文件或完全恢复。

3. 撤回最近的提交

如果你想要撤回最近的提交(但保留更改在工作区),可以使用:

git reset --soft HEAD~1
  • HEAD~1 表示最近的提交,--soft 选项会将更改保留在暂存区。

如果你想要撤回最近的提交并将更改移回工作区(不保留在暂存区),可以使用:

git reset HEAD~1

4. 撤回多个提交

如果要撤回多个提交,可以指定要回退到的提交。例如,回退到上两次提交:

git reset --soft HEAD~2

这会将最近的两个提交撤回,但保留所有更改在暂存区。

5. 撤回提交并完全删除更改

如果你想要撤回提交并完全删除更改(即不保留在工作区),可以使用:

git reset --hard HEAD~1
  • 注意:使用 --hard 选项会删除所有未提交的更改,无法恢复。

git_revert_58">6. 使用 git revert

如果你已经推送了提交到远程分支,通常不建议使用 reset,因为这会修改历史,可能导致其他开发者的工作出现问题。在这种情况下,你可以使用 git revert

git revert <commit>
  • 这将创建一个新的提交,它的内容是指定提交的反向更改,从而“撤销”该提交的效果。

7. 示例

撤回未暂存的修改
git checkout -- example.txt
撤回已暂存的修改
git reset HEAD example.txt
撤回最近的提交
git reset --soft HEAD~1
git_revert__88">使用 git revert 撤回提交
git revert abc1234

8. 总结

  • 未暂存的修改:使用 git checkout -- <file>
  • 已暂存的修改:使用 git reset HEAD <file>
  • 最近的提交:使用 git reset --soft HEAD~1git reset HEAD~1
  • 撤回多个提交:使用 git reset --soft HEAD~n
  • 通过创建反向提交撤回:使用 git revert <commit>

选择合适的方法根据你的需求,以确保不会意外丢失重要的更改。


http://www.niftyadmin.cn/n/5688774.html

相关文章

sentinel原理源码分析系列(二)-动态规则和transport

本文是sentinel原理源码分析系列第二篇&#xff0c;分析两个组件&#xff0c;动态配置和transport 动态规则 Sentinel提供动态规则机制&#xff0c;依赖配置中心&#xff0c;如nacos&#xff0c;zookeeper&#xff0c;组件支持动态配置&#xff0c;模板类型为规则&#xff0c;支…

大模型~合集6

我自己的原文哦~ https://blog.51cto.com/whaosoft/11566566 # 深度模型融合&#xff08;LLM/基础模型/联邦学习/微调等&#xff09; 23年9月国防科大、京东和北理工的论文“Deep Model Fusion: A Survey”。 深度模型融合/合并是一种新兴技术&#xff0c;它将多个深度学习模…

云原生周刊:Argo CD v2.13 发布候选版本丨2024.9.30

开源项目推荐 Argo Events Argo Events 是一款事件驱动的工作流自动化框架&#xff0c;专门为 Kubernetes 环境开发。 UptimeFlare UptimeFlare 是一个基于 Cloudflare Workers 的免费无服务器监控和状态页开源项目 BunkerWeb BunkerWeb 是一个开源的下一代 Web 应用防火…

FreeRTOS篇13:延时函数

一.什么是延时函数&#xff1f; 二.延时函数分类 相对延时&#xff1a;vTaskDelay 绝对延时&#xff1a;vTaskDelayUntil 三.vTaskDelay 与 HAL_Delay 的区别 vTaskDelay 作用是让任务阻塞&#xff0c;任务阻塞后&#xff0c;RTOS系统调用其它处于就绪状态的优先级最高的…

Redis篇(Redis原理 - RESP协议)

目录 一、简介 二、Redis通信协议 基于Socket自定义Redis的客户端 三、Redis内存回收 1. 过期key处理 1.1. 惰性删除 1.2. 周期删除 1.3. 知识小结 2. 内存淘汰策略 一、简介 Redis是一个CS架构的软件&#xff0c;通信一般分两步&#xff08;不包括pipeline和PubSub&a…

基于SSM的定制衣服系统的设计与实现(定制衣服管理平台的设计与开发、智慧服装定制系统的设计与实现、定制衣服管理系统的设计与实现(源码+定制+参考文档)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

Stable Diffusion绘画 | 来训练属于自己的模型:炼丹参数调整--步数设置与计算

要想训练一个优质的模型&#xff0c;一定要认识和了解模型训练中&#xff0c;参数的作用和意义。 整个模型训练的过程&#xff0c;参数并不是一成不变的&#xff0c;也没有固定的模板&#xff0c; 当我们修改了模型训练里面的某个参数&#xff0c;很可能就需要连带其他一系列…

推送k8s镜像到阿里云服务器

1、服务打包 2、打包后进入Dockerfile的同级目录 运行 docker build -t 镜像名:镜像版本 . (这个点是当前目录的意思&#xff0c;不能忽略)例如 docker build -t trac:v1.0.4 .3、上传镜像到阿里云镜像服务 注意选择区域 例如&#xff1a; docker tag 70743d9bdba3 registr…