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

一、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了,如果文章对你有帮助希望关注支持一下。

原文地址:http://leisure.wang/?p=472

git push撤销、git commit 撤销、git add撤销、修改git提交信息的更多相关文章

  1. Git 修改历史提交信息 commit message

    修改最近一条提交的消息 git commit --amend 进入vim模式 按字母 o 或者 insert键 开始修改内容 按 esc 推出编辑,最常用的是输入":q"直接退出, ...

  2. git 修改上次提交信息 与 撤销此操作.

    git commit --amend 修改刚才提交的commit信息 撤销 git commit --amend 思路是使用 git reflog 查看在哪里ammend的.找到HEAD{N}, N是 ...

  3. git 修改历史提交信息

    当你不小心,写错了提交的注视/信息,该如何处理呢.理论上,SCM是不应该修改历史的信息的,提交的注释也是.   不过在git中,其commit提供了一个--amend参数,可以修改最后一次提交的信息. ...

  4. git push完代码 想撤回 并保留之前修改的代码 / 修改完代码 发现分支不对 想切换分支 /恢复已修改的文件

    git reset --soft xxxx // xxxx是版本号 回退 git stash //保留当前分支修改的代码 git checkout xxx //切换到xxx分支 git stash l ...

  5. git git push某一次的commit记录

    $ git push <remote name> <commit hash>:<remote branch name> # Example:$ git push o ...

  6. git add , git commit 添加错文件 撤销

    1. git add 添加 多余文件 这样的错误是由于, 有的时候 可能 git add . (空格+ 点) 表示当前目录所有文件,不小心就会提交其他文件 git add 如果添加了错误的文件的话 撤 ...

  7. 02_创建Git仓库,克隆仓库,git add,git commit,git push,git pull,同行冲突,不同行冲突的结局方案,git mergetool的使用

    1 创建Git资源库,残酷目录信息 创建git资源库的命令: git init –bare 仓库名称 (其中-bare表示的意思是空的库的意思) 进入E:\software\repository\gi ...

  8. git push 提示

    我运行git push -u origin master  时提示如下: To git@github.com:userName/project.git ! [rejected] master -> ...

  9. git push 本地项目推送到远程分支

    大家有的时候,会在本地新建项目,这里说一下在本地项目建立本地git仓库,然后push到远程仓库的步骤 1.在本地项目的文件夹下,git仓库初始化 git init 初始化本地git仓库 2. git ...

  10. git push 本地项目推送到远程分支[z]

    大家有的时候,会在本地新建项目,这里说一下在本地项目建立本地git仓库,然后push到远程仓库的步骤 1.在本地项目的文件夹下,git仓库初始化 git init 初始化本地git仓库 2. git ...

随机推荐

  1. php--static用法

    static关键字声明一个属性或方法是和类相关的,而不是和类的某个特定的实例相关,因此,这类属性或方法也称为“类属性”或“类方法”. 如果访问控制权限允许,可不必创建该类对象而直接使用类名加两个冒号“ ...

  2. [Batch脚本] if else 的格式

    必须写成一行 ) else (,否则报错. if %abc%=="yes" ( ... ) else ( ... )

  3. JDK14的新特性:Lombok的终结者record

    目录 简介 新的Record类型 探讨Record的秘密 record扩展 总结 JDK 14的新特性:Lombok的终结者record 简介 自从面向对象产生之后,程序界就开始了新的变化,先是C发展 ...

  4. Shutdown SpringBoot App

    文章目录 Shutdown Endpoint close Application Context 退出SpringApplication 从外部程序kill App Shutdown SpringBo ...

  5. 【用AI开挂的人生】5岁学编程,12岁进IBM

    " 跟普通孩子比起来,14岁少年Tanmay Bakshi身上有无数光环: 5岁开始对计算机感兴趣 9岁发布了第1个iOSAPP 12岁成为IBM沃森最年轻的程序员 现任IBM Watson ...

  6. WordPress发布文章/页面时自动添加默认的自定义字段

    如果你每篇文章或页面都需要插入同一个自定义字段和值,可以考虑在WordPress发布文章/页面时,自动添加默认的自定义字段.将下面的代码添加到当前主题的 functions.php 即可: 1 2 3 ...

  7. Linux下进程的创建(system(); fork(); exec*())

    0. system(); system()函数通过调用shell程序来执行所指向的命令(效率低),相当于先fork(),再execve(): 特点:原进程和子进程各自运行,且原进程需要等子进程运行完后 ...

  8. 图论--最长路--基于SPFA的调整模板

    #include<iostream> #include<queue> #include<algorithm> #include<set> #includ ...

  9. 聊聊select, poll 和 epoll

    聊聊select, poll 和 epoll 假设项目上需要实现一个TCP的客户端和服务器从而进行跨机器的数据收发,我们很可能翻阅一些资料,然后写出如下的代码. 服务端 void func(int s ...

  10. 题目分享Q

    题意:给出一个N个点的树,找出一个点来,以这个点为根的树时,所有点的深度之和最大 分析:这可以说是换根法的裸题吧 首先考虑对一个给定的根如何计算,这应该是最简单的那种树形dp吧甚至可能都不算dp(好像 ...