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中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

PyInstaller打包selenium-wire过程中常见问题和解决指南

《PyInstaller打包selenium-wire过程中常见问题和解决指南》常用的打包工具PyInstaller能将Python项目打包成单个可执行文件,但也会因为兼容性问题和路径管理而出现各种运... 目录前言1. 背景2. 可能遇到的问题概述3. PyInstaller 打包步骤及参数配置4. 依赖