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中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-