git 撤销全部的commit_git如何撤销commit的方法(未push)

撤销commit一般用git reset ,语法如下:

git reset [ --mixed | --soft | --hard] []

1.使用参数--mixed(默认参数),如git reset --mixed 或git reset

撤销git commit,撤销git add,保留编辑器改动代码

2.使用参数--soft,如git reset --soft

撤销gitcommit,不撤销git add,保留编辑器改动代码

3.使用参数--hard,如git reset --hard ——此方式非常暴力,全部撤销,慎用

撤销gitcommit,撤销git add,删除编辑器改动代码

开始撤销commit的示例:

输入git log,我们可以看到最近的3次提交,最近一次提交是test3,最早的一次是test1,其中一大串黄色的字母是commit id(版本号)

如果嫌输出信息太多,可加上--pretty=oneline参数,即

git log --pretty=oneline

接下来,按下键盘上的字母q退出git日志,准备进行撤销commit

Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交commit id,上一个版本就是HEAD^(或者HEAD~1),上上一个版本就是HEAD^^(或者HEAD~2),同理往上N个版本写N个^不太现实,我们写成HEAD~100。

现在,我们要把当前版本test3上一个版本test2,就可以使用git reset命令:git reset --hard HEAD^,再查看日志,发现已经剩下2个commit版本了

git reset --hard HEAD^

最新的那个版本test3已经看不到了,此时你想起有一行代码写得很好,想回到test3版本看下,怎么做?

办法其实还是有的,只要上面的命令行窗口还没有被关掉,记录还是在,使用命令git reset --hard commit_id可以回退到指定的版本,比如当前例子,我们找到那个test3的commit id是e09af7ae711e2a79c15144c1e792fb2e27d201ff,然后输入下面指令就回来了

git reset --hard e09af7ae711e2a79c15144c1e792fb2e27d201ff

版本号可以不用写全,输入前4位或更多也是可以,Git会自动去找,不能只写前一两位,因为Git可能会找到多个版本号。比如,看完test3版本的代码后,现在想回退到最初test1版本,我们找到那个test1的commit id是ab7b0c2b6e10a20d524156a81f6d4bc15a4ea7f3,然后输入下面指令就回来了

git reset --hard ab7b

最后在Git中,总是有后悔药可以吃的,Git提供了一个命令git reflog用来记录你的每一次命令,通过它可以查到每个commit id,方便你前进或者回退到指定的版本

到此这篇关于git如何撤销commit的方法(未push)的文章就介绍到这了,更多相关git撤销commit内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用Git进行版本控制时,我们可以使用`git commit`命令将修改的文件提交到本地仓库。然而,有时候我们会不小心提交了错误的内容或者需要对之前的提交进行修改。当我们还没有将这些提交推送到远程仓库时,我们可以使用以下方法撤销提交。 一种常用的方法是使用`git reset`命令。通过`git reset`命令,我们可以将HEAD移动到想要撤销到的提交上。例如,如果我们想要撤销最新的提交,可以使用`git reset HEAD~1`命令。这样,最新的提交将被移除,并且修改的文件将回到暂存区,我们可以对其进行修改或重新提交。 另一种方法是使用`git revert`命令。通过`git revert`命令,我们可以创建一个新的提交来撤销之前的提交。例如,如果我们想要撤销最新的提交,可以使用`git revert HEAD`命令。这样,Git会创建一个新的提交,将之前的提交的更改反转,并将其应用到当前分支上。 无论是使用`git reset`还是`git revert`,请注意,这些操作都会更改Git历史记录。如果我们之前的提交已经被推送到远程仓库,那么需要小心地使用这些命令,以免影响其他人的工作。 总结起来,当我们需要撤销推送的提交时,可以使用`git reset`或`git revert`命令来实现。通过这些命令,我们可以撤销提交并重新修改或创建新的提交。但是请谨慎操作,确保不会对 Git 的历史记录造成不必要的麻烦。 ### 回答2: 当我们使用Git进行版本控制时,有时候会意外地提交了一次错误的commit,但是还没有push到远程仓库。这时候我们可以使用以下方法撤销该次commit。 首先,可以使用以下命令查看最近几次的commit记录: ``` git log ``` 然后找到我们想要撤销commit的哈希值(commit hash)。接下来,可以使用以下命令来撤销该次commit,但是保留该次commit所做的更改: ``` git revert <commit hash> ``` 该命令会创建一个新的commit,将之前的commit中的更改撤销掉。 如果我们想要完全删除该次commit以及相关的更改,可以使用以下命令: ``` git reset <commit hash> ``` 该命令会将HEAD指针和当前分支指针都指向指定的commit,并且会丢弃掉指定commit之后的所有更改。 但是需要注意的是,以上的操作只能在本地仓库进行,如果该次commit已经被push到了远程仓库,那么需要再进行一次push来同步到远程仓库上。 总结来说,如果要撤销一次pushcommit,可以使用`git revert`命令来创建一个新的commit撤销该次commit的更改,或者使用`git reset`来完全删除该次commit以及相关的更改。 ### 回答3: 在Git中,如果我们在本地仓库中提交了一个commit,但是还没有将这个commit推送到远程仓库,我们可以使用`git reset`命令来撤销这个commit。 首先,我们可以使用`git log`命令查看提交记录,找到需要撤销commit的哈希值。 然后,我们可以使用`git reset`命令来撤销commit。有两种方式可以选择: 1. 使用`git reset --hard`命令来撤销commit并丢弃所有的修改,这将会将当前分支指向我们指定的commit并丢弃其之后的所有提交。 2. 使用`git reset --soft`命令来撤销commit但保留所有的修改,这将会将当前分支指向我们指定的commit并保留其之后的修改作为提交的修改。 示例: 假设我们需要撤销commit的哈希值是abcdefg。 1. 使用`git reset --hard abcdefg`命令来撤销这个commit并丢弃所有的修改。 2. 使用`git reset --soft abcdefg`命令来撤销这个commit但保留所有的修改。 注意: 1. 使用`git reset`命令会直接修改本地分支,需要谨慎操作。 2. 如果已经推送过的commit需要撤销,推荐使用`git revert`命令来创建一个新的提交来撤销原来的commit。 总结: 通过使用`git reset`命令来撤销commit,我们可以保持本地仓库的修改状态和历史记录的完整性,而不会将错误或不需要的commit推送到远程仓库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值