oneisx oneisx
首页
Java
Golang
Python
Linux
版本控制
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

oneisx

睁不开眼的雷
首页
Java
Golang
Python
Linux
版本控制
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • Git

    • Git各种撤销
      • 一、git push撤销
        • 1.1 使用场景
        • 1.2 示例场景
        • 1.3 示例目标
        • 1.4 详细步骤
      • 二、git commit撤销
        • 2.1 使用场景
        • 2.2 命令使用
      • 三、git add撤销
        • 3.1 使用场景
        • 3.2 命令使用
      • 四、修改git提交信息
        • 4.1 使用场景
        • 4.2 命令使用
      • 五、恢复文件到上一次提交时的样子
        • 5.1 使用场景
        • 5.2 命令使用
    • Git常用命令
  • 版本控制
  • Git
oneisx
2022-01-07

Git各种撤销

虽然自觉是一个Git工具的老手了,但是平时犯了一点错误,就发现有点捉襟见肘了。就好像今天我把一些代码玩坏了,想撤回到前几个版本去(此时已经push到远程分支),但是仔细一想:卧槽,这操作我好像不太熟练啊,于是乎就有了这篇文章了,介绍如何撤销git push、撤销git commit、撤销git add、修改git提交信息

# 一、git push撤销

# 1.1 使用场景

代码已经修改并push到远程分支,想撤回到前几个版本,并且会删除本地代码所做的修改!

# 1.2 示例场景

如下图。

# 1.3 示例目标

撤销第二、第三次提交代码,回到第一次提交代码

# 1.4 详细步骤

# 1.4.1 获取第一次提交commit版本号

在idea的Terminal窗口输入git log查看提交日志,结果如图:

将目标commit版本号复制保存留用。

如果git log无法正常显示中文,在Terminal中使用如下命令:

set LESSCHARSET=utf-8

# 1.4.2 将本地代码撤销至目标commit版本(高危操作,请明确利害关系)

执行命令:

git reset --hard 57f89f403fd8b373a44cf5ae8481402a74799bee

结果:

HEAD is now at 57f89f4 'Git演示:第一次提交'

验证结果:

  • 本地分支log

  • 远程分支log

此时,本地分支第二、第三次提交已经撤销删除了!

# 1.4.3 覆盖远程分支代码(高危操作,请明确利害关系)

请明确本地分支代码是最终的代码!否则谨慎操作!执行命令:

git push --force

执行完这一步,git push撤销操作就完成了,git log如图:

# 二、git commit撤销

# 2.1 使用场景

代码已经git add,并且git commit,但是还没有git push

# 2.2 命令使用

git reset --soft HEAD~1

## 如果进行了2次commit,想都撤回,可以使用:
git reset --soft HEAD~2

## ... 以此类推

# 三、git add撤销

# 3.1 使用场景

代码已经执行了git add操作,想撤销git add操作。

# 3.2 命令使用

## 全部撤销
git reset HEAD

## 指定文件撤销 git reset HEAD <file>,文件名可通过git status命令获取。
git reset HEAD src/main/java/wang/leisure/gitpractice/FirstClass.java

# 四、修改git提交信息

# 4.1 使用场景

不修改代码内容,只修改commit信息,在git commit操作之后,git push操作之前。如果你在git push之后操作,也会将本地commit信息变更,但是这样会导致与远程分支信息不一致,所以尽量不要在git push之后操作。

# 4.2 命令使用

直接在Terminal中输入:

git commit --amend

命令输入之后,就是Vim类似的修改、保存操作了。

# 五、恢复文件到上一次提交时的样子

# 5.1 使用场景

文件做了很多修改,但是还没有git add,又不想一步步回退。

# 5.2 命令使用

## 文件名可通过git status命令获取
git checkout -- src/main/java/wang/leisure/gitpractice/FirstClass.java

至此,有关git操作撤销相关的内容就分享结束了,有任何不懂的可以留言哦。深夜1:15了,如果文章对你有帮助希望关注支持一下。

编辑 (opens new window)
#Git
上次更新: 2022/01/08, 23:34:06
Git常用命令

Git常用命令→

最近更新
01
看了这篇你就会手写RPC框架了
01-07
02
Git常用命令
01-07
03
Linux常用命令
01-07
更多文章>
Theme by Vdoing | Copyright © 2022-2022 oneisx | Apache License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式