Git进阶命令-reset
之前有关Git,写过一片文章: Git五个常见问题及解决方法
一、reset命令使用场景
有时候我们提交了一些错误的或者不完善的代码,需要回退到之前的某个稳定的版本,面对这种情况有两种解决方法:
解决方法1:修改错误内容,再次commit一次
解决方法2:使用git reset 命令撤销这一次错误的commit
第一种方法比较直接,但会多一次commit记录,同时并不是所有场景都可以这么做。
所以建议使用第二种方法,因为错误的commit没必要保留下来。
二、reset命令
git reset 命令用于回退版本
,可以指定退回某一次提交的版本。
reset 命令的原理是根据 commitId 来恢复版本。
因为每次提交都会生成一个 commitId,所以说 reset 可以帮你恢复到历史的任何一个版本。
这里的版本和提交是一个意思,一个 commitId 就是一个版本
命令格式如下:
git reset [--soft | --mixed | --hard] [HEAD]
常用命令
# 回退所有内容到上一个版本
git reset HEAD^
# 回退test.txt这个文件的版本到上一个版本
git reset HEAD^ test.txt
# 向前回退到第3个版本
git reset HEAD~3
# 回退到某个版本51363e6
git reset 51363e6
注意:对于已经 push 的 commit,也可以使用reset命令,不过再次 push 时,由于远程分支和本地分支有差异,需要强制推送 git push -f 来覆盖被 reset 的 commit。
这里非常需要注意,因为 git push -f
是一个非常危险的命令。
如果在 git push -f 之前有其他同事 push 新代码。那么同事提交代码会丢失。
所以这里一定要注意 git push -f 之前要先 git pull 拉下是否有新提交代码。
三、reset参数有哪些?
option 参数的选项有以下几种
git reset --mixed
:此为默认方式,将撤回的代码,存放到工作区。同时会保留本地未提交的内容。
git reset --soft
:回退到某个版本 。将撤回的代码,存放到暂存区。同时会保留本地未提交的内容。
git reset --hard
:彻底回退到某个版本,丢弃将撤回的代码,本地没有commit的修改会被全部擦掉。(慎用
)
下面对这三种参数分别一一通过示例演示
四、reset --mixed
默认方式,将撤回的代码,存放到工作区。同时会保留本地未提交的内容。
在代码提交后,我发现这次提交也就是 commitId 为 7812249,提交错了,需要撤回。
同时这个时候呢,本地又新增修改了一些代码
执行命令
git reset d0eda46
注意
这里的commitId不是提交代码2的,而是提交代码1的,因为我们想的是回到是1这个版本,别搞错了
可以看出本地的代码和撤回的代码都在,且都在工作区
。
我们再来看下提交日志
git log --oneline
可以看到 提交代码2
的提交记录已经没有了。
五、reset --soft
soft和mixed差别并不大,无非就是一个回退到暂存区一个回退到工作区。
我们来演示下,把上面三个文件重新提交一次
$ git commit -a -m '提交代码2'
[feature ebb89a1] 提交代码2
3 files changed, 5 insertions(+), 2 deletions(-)
然后再来执行reset命令
git reset --soft d0eda46
可以看出撤回的都返回在暂存区。
六、reset --hardt
这个命令和前面差别就非常大了,它不仅会丢弃错误commit提交的代码,而且本地没有commit的修改会被全部擦掉,关键是这种情况本地代码一旦擦掉是没有任何办法在找回来了。
同样我们把上面的代码再次提交
$ git commit -m '提交代码3'
[feature de970f2] 提交代码3
3 files changed, 5 insertions(+), 2 deletions(-)
然后再来执行reset命令
git reset --hard d0eda46
在看本地
$ git status
On branch feature
nothing to commit, working tree clean
在工作区和暂存区已经没有任何代码了,也就是如果这个时候你本地开发的代码没有提交,那就永远也找不回来了。
那之前提交过的但又撤回的 提交代码3
的代码可以找回吗?
这个是可以的。
我们通过 git log --oneline
是找不回的。
找不到 提交代码3
的记录了。 那怎么办呢?
可以通过 git reflog 命令实现找回
执行命令
git reflog
这里能找到 commit 提交代码3
的记录。那现在要做的就是撤回到当前提交的位置。
执行命令
git reset de970f2
全部回来啦。
注意
切记!!!工作区有未提交的代码时不要用这个命令,因为工作区会回滚,你没有提交的代码就再也找不回了。
声明: 公众号如需转载该篇文章,发表文章的头部一定要 告知是转至公众号: 后端元宇宙。同时也可以问本人要markdown原稿和原图片。其它情况一律禁止转载!
Git进阶命令-reset的更多相关文章
- git进阶命令
首先, clone 一个远端仓库,到其目录下: $ Git clone git://example.com/myproject $ cd myproject 然后,看看你本地有什么分支: $ git ...
- 超级有用的git reset --hard和git revert命令
很多时候,git新手容易误操作,比如,在levelIISZ-1.4.dev分支下,运行了git pull idc cpp-1.0的结果,这样做麻烦很大,经常导致maven项目格式不正确,这个时候,可以 ...
- Git 进阶指南(git ssh keys / reset / rebase / alias / tag / submodule )
在掌握了基础的 Git 使用 之后,可能会遇到一些常见的问题.以下是猫哥筛选总结的部分常见问题,分享给各位朋友,掌握了这些问题的中的要点之后,git 进阶也就完成了,它包含以下部分: 如何修改 ori ...
- git reset --hard和git revert命令
git reset --hard和git revert命令 git误操作时可以用git reset –hard 去撤销这次修改, 但是这样做也有问题,可能在之前本地有没有提交的修改也都消失了, ...
- git 常用命令 mv rm checkout revert reset
关于上节讲的git add 时需要添加注释信息,也可以在git commit时再添加 laoni@DESKTOP-TPPLHIB MINGW64 /c/laoni/PycharmProjects/gi ...
- Git进阶:常用命令和问题案例整理
一.前言 整理常用git命令和以及在实际使用的过程中碰到的问题案例,旨在git进阶,提升工作开发效率,有需要补充的小伙伴欢迎下方留言,本篇持续更新中... 二.命令 配置用户名和邮箱 git conf ...
- Git 常用命令
一.初始環境配置 git config --global user.name "John Doe"git config --global user.email johndoe@ex ...
- Git 进阶指南
转自: https://github.com/kaiye/kaiye.github.com/issues/7 在掌握了基础的 Git 使用 之后,可能会遇到一些问题.以下是猫哥筛选总结的部分常见问题, ...
- git checkout 命令详解
转自:http://www.cnblogs.com/hutaoer/archive/2013/05/07/git_checkout.html?utm_source=tuicool&utm_me ...
- git checkout 命令详解(转)
在日常的git操作中,git checkout——检出,是我们的常用命令.最为常用的两种情形是创建分支和切换分支. 在下面的命令中,使用了一些简写,在这里说明一下: git st # git stat ...
随机推荐
- 【Linux】常用基本指令大汇总系列(篇一)【超详细的图解保姆教程】
常用基本指令大汇总系列(篇一) 大家好,欢迎大家来到我的博客.从今天开始,博主就要开启一个全新的系列了!Linux操作系统常用基本指令汇总系列,当大家按顺序学完这个系列,在Linux上编写基本的C语言 ...
- PyTorch中实现Transformer模型
前言 关于Transformer原理与论文的介绍:详细了解Transformer:Attention Is All You Need 对于论文给出的模型架构,使用 PyTorch 分别实现各个部分. ...
- Codeforces Round #821 (Div. 2) A-E
比赛链接 A 题解 知识点:贪心. 下标模 \(k\) 相同分为一组,共有 \(k\) 组,组间不能互换,组内任意互换. 题目要求连续 \(k\) 个数字,一定能包括所有的 \(k\) 组,现在只要在 ...
- Android自动化测试框架uiautomator2详解
1 uiautomator2 简介 uiautomator2 是 一种 Android 自动化测试框架,提供了点击.长按.输入文本.滑动.拖拽.截屏等方法,能够模拟用户的各种动作.用户可以通过控件 ...
- SpringCloud Config配置中心实战
介绍 本文以理论结合实践编写,篇幅较长,各位看官保持耐心:),部分内容引用自网络. 什么是配置中心? 当微服务过多的时候,每个微服务的配置很难集中管理.SpringCloud Config通过git代 ...
- Detours 的使用
Detours 是一个用于在 ARM, ARM64, X86, X64 和 IA64 机器上拦截二进制函数的库. Detours 最常用来拦截应用程序中的 win32 api 调用,比如添加调试工具. ...
- windbg 分析 32 位进程的 64 位转储文件
场景: x86 的项目在 x64 的 windows 机器上运行时出现未响应的情况,使用任务管理器创建该进程的转储文件 因为项目是 32 位的,所以使用 x86 的 windbg 来调试 dmp 文件 ...
- win32 - 在进程之间获取事件通知(CreateEvent)
只需要记住使用OpenEvent来同步Event对象. Project A: #define _CRT_SECURE_NO_WARNINGS #include <Windows.h> #i ...
- 了解企业架构EA(Enterprise Architecture)
一.企业架构简介 企业架构:Enterprise Architecture,EA,或企业体系结构,是在信息系统架构设计与实践基础上发展起来的一个特殊领域. 但是企业架构现在还没有一个公认的定义,综合现 ...
- 【Android逆向】frida 破解 滚动的天空
1. apk 安装到手机中 2. 玩十次之后,会提示 充值 3. adb shell dumpsys window | grep mCurrentFocus 查看一些当前activity是哪一个 是 ...