git 盘点各种失误操作解决方法

2023-12-08 22:49

本文主要是介绍git 盘点各种失误操作解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、commit 之后发现提交中包含的文件不对
      • 1.1 场景说明
      • 1.2 解决方法
      • 1.3 注意事项
    • 二、commit 之后没有 push 想要修改 commit 的注释信息
      • 2.1 场景说明
      • 2.2 解决方法
    • 三、git stash pop出现冲突后回滚
      • 3.1 场景说明
    • 四、git cherry-pick出现冲突后回滚
      • 4.1 场景说明

一、commit 之后发现提交中包含的文件不对

1.1 场景说明

我们对 A文件和 B文件进行了修改,然后我们想对 A文件的修改进行一次提交。但是我们在git add 的时候把 B文件也添加上了,这就导致这次提交把 A、B两个文件的修改都提交了。

假设我们的提交记录如下

提交2 对A文件进行修改
提交1 项目初始化

1.2 解决方法

执行如下命令就可以撤销本次commit 并且我们的修改也是保留的

git reset HEAD~1

1.3 注意事项

这里特别和另外两个命令做对比,因为我自己就犯过类似的错误,只想撤销 commit,重写提交一次。结果执行了下面的命令导致修改的内容也不见了(真的是血的教训)。

所以这里特别强调,下面这两个命令会撤销你修改的内容,完全回到上上次提交(也就是提交1)之后的样子
不要用
不要用
不要用

# 提交2的提交记录也随之消失
git reset --hard HEAD~1
# 提交2的提交记录依然存在
git revert 提交2的版本号

二、commit 之后没有 push 想要修改 commit 的注释信息

2.1 场景说明

我们对A文件进行了修改,并提交注释写成了 “对B文件进行修改” 。这时我们想要修改这条注释信息为 “对A文件进行修改”

2.2 解决方法

执行如下命令就会进行修改页面,按 i 进入编辑模式对提交内容进行修改,按ESC推出编辑模式。输入 :wq 退出并保存

git commit --amend

三、git stash pop出现冲突后回滚

3.1 场景说明

之前我使用 git stash 将修改保存在了暂存区中,但是在后期我已经不需要之前修改的这些内容了。然而我使用了 git stash pop 恢复了这些修改。导致了大量的冲突,这是我们并不想解决这些冲突所以就需要回滚。使用如下命令即可

git reset --hard

四、git cherry-pick出现冲突后回滚

4.1 场景说明

使用 git cherry-pick 从其他分支挑选部分提交到指定分支上时,输入了错误的commitId ,这时可以使用如下命令恢复到git cherry-pick之前的状态

git cherry-pick --abort

这篇关于git 盘点各种失误操作解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/471568

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作