在Git中,我们可以用 git log命令查看我们修改的历史记录

C:\Users\Administrator\Documents\GitHub\learngit [master]> git log
commit 06da0ffc8ff902d1b7d55968dd2822a6e0cc7ac9
Author: Tryking <260119064@qq.com>
Date: Thu Mar 10 14:29:22 2016 +0800 add World commit f4fa07feb10862f0d0d6a44fb88f5ede6ae75771
Author: Tryking <260119064@qq.com>
Date: Thu Mar 10 13:57:50 2016 +0800 wrote a readme file

git log命令显示从最近到最远的提交日志,我们可以看到2次提交,最近的一次是add World,最早的一次是wrote a readme file。

如果嫌输出信息太多,看得眼花缭乱的,可以试试加上–pretty=oneline参数:

C:\Users\Administrator\Documents\GitHub\learngit [master]> git log --pretty=oneline
06da0ffc8ff902d1b7d55968dd2822a6e0cc7ac9 add World
f4fa07feb10862f0d0d6a44fb88f5ede6ae75771 wrote a readme file

查看了修改的历史记录后,我们就可以用 git reset 进行版本回退了

首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交06da0ffc8ff902d1b7d55968dd2822a6e0cc7ac9(这个是commit id,是一个SHA1计算出来的一个非常大的数字,用十六进制表示),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

现在,我们要把当前版本“add World”回退到上一个版本“wrote a readme file”,就可以使用git reset命令:

C:\Users\Administrator\Documents\GitHub\learngit [master]> git reset --hard HEAD^
HEAD is now at f4fa07f wrote a readme file

之后我们可以用 cat 命令查看readme.txt的内容是不是回退回去的版本

C:\Users\Administrator\Documents\GitHub\learngit [master]> cat readme.txt
Hello

我们用 git log 再看看现在版本库的状态:

C:\Users\Administrator\Documents\GitHub\learngit [master]> git log
commit f4fa07feb10862f0d0d6a44fb88f5ede6ae75771
Author: Tryking <260119064@qq.com>
Date: Thu Mar 10 13:57:50 2016 +0800 wrote a readme file

最新的那个版本 add World 已经看不到了!想再回去已经回不去了,怎么办?

办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个add World的 commit id 是06da0ffc8ff…,于是就可以指定回到未来的某个版本:

C:\Users\Administrator\Documents\GitHub\learngit [master]> git reset --hard 06da

HEAD is now at 06da0ff add World

版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。

再看看readme.txt的内容:

C:\Users\Administrator\Documents\GitHub\learngit [master]> cat readme.txt
HelloWorld

Git可以记录你的每次命令:git reflog

现在,假如你回退到了某个版本,关掉了电脑,第二天早上就后悔了,想恢复到新版本怎么办?找不到新版本的commit id怎么办?

Git提供了一个命令 git reflog 用来记录你的每一次命令:

C:\Users\Administrator\Documents\GitHub\learngit [master]> git reflog
06da0ff HEAD@{0}: reset: moving to 06da
f4fa07f HEAD@{1}: reset: moving to HEAD^
06da0ff HEAD@{2}: commit: add World
f4fa07f HEAD@{3}: commit (initial): wrote a readme file

这样你就可以看到你需要的 commit id 了,放心的回去吧!

Git使用:版本回退的更多相关文章

  1. Git(时光机-版本回退)

    现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下: Git is a distributed version control system. ...

  2. Git学习--版本回退

    现在,你已经学会了修改文件,然后把修改提交到Git版本库,现在,再练习一次,修改readme.txt文件如下: Git is a distributed version control system. ...

  3. idea中git远程版本回退

    idea中git远程版本回退 2017年10月15日 15:25:36 gomeplus 阅读数:19313 工作中遇到git远程仓库需要回退到历史版本的问题,根据网上的搜索结果结合自己的实践,整理了 ...

  4. git指令-版本回退

    git指令-版本回退 回顾: 1. 修改文件 2. 添加到暂存区并提交 回顾对readme共三次修改: 1. 版本1:wrote a readme file Git is a version cont ...

  5. Git回版本回退

    这里我们使用命令行的方式对已经提交的版本进行强行回退操作~~~ 一.将git的安装目录bin放到path路径中, 如下图所示: 二.进入cmd界面,依次输入下面内容即可(git 远程仓库 回退到指定版 ...

  6. git远程版本回退

    本文为博主原创,未经允许不得转载: 之前在git提交版本时,发现将新开发的代码提交到了另一个分支上,为了不影响提交分支代码的 功能,需要回退到之前的版本. 在使用命令回退的时候,一直没有回退成功,有个 ...

  7. git实现版本回退

    1. 首先查看自己的版本: ***:~/piaoshifu_object/epiao.piaoshifu.cn$ git log commit c8d5c67861d2d0e21856cc2b4f60 ...

  8. git reset 版本回退的三种用法总结

    git reset (–mixed) HEAD~1 回退一个版本,且会将暂存区的内容和本地已提交的内容全部恢复到未暂存的状态,不影响原来本地文件(未提交的也不受影响) git reset –soft ...

  9. git reset 版本回退

    git log 查看所有提交信息. commit 67692318180bed6b2a17db0708cfbe0231e33db3 (HEAD -> master) Author: kingBo ...

  10. git的版本回退探索

    简介 今天改完代码匆忙提交,上线发现有问题,那怎么办?废话,赶紧回滚,那怎么回滚,开始用git reset [--soft | --mixed | --hard 命令,但这命令真的能达到我预期的效果吗 ...

随机推荐

  1. 使用.NET 6开发TodoList应用(2)——项目结构搭建

    为了不影响阅读的体验,我把系列导航放到文章最后了,有需要的小伙伴可以直接通过导航跳转到对应的文章 : P TodoList需求简介 首先明确一下我们即将开发的这个TodoList应用都需要完成什么功能 ...

  2. Java应用日志如何与Jaeger的trace关联

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  3. JavaFx Tooltip悬浮提示使用及自定义

    原文:JavaFx Tooltip悬浮提示使用及自定义 | Stars-One的杂货小窝 本篇是基于TornadoFx框架对Tooltip组件进行讲解,使用Kotlin语言,和传统Java使用有所区别 ...

  4. 阿里云ilogtail收集自建Kubernetes容器日志文件

    背景 1,k8s属于自建. 2,需要收集应用服务容器里面指定目录的日志. 3,计划收集所有私有云php和nginx日志. 4,日志格式化处理. 思考 1,一个私有云一个Project,还是统一放入一个 ...

  5. epoll linux和协程gevent的区别

    epoll linux  底层是libevent.so模块实现的 gevent也是IO多路复用,底层是libevent.so模块实现的是更上层的封装 Twsited异步网络框架.代码量非常大.在开源p ...

  6. JAVA获取当前日期所在的周一到周日的所有日期集合

    /** * 获取当前日期所在的周一到周日的所有日期集合 * @return */ public static List<Date> getWeekDateList() { Calendar ...

  7. -fno-rtti -fno-exceptions

    -fno-rtti 禁用运行时类型信息-fno-exceptions 禁用异常机制一般只有对程序运行效率及资源占用比较看重的场合才会使用, 如果要做这两个的话最好连libstdc++和其他所有的的c+ ...

  8. 【LeetCode】1120. Maximum Average Subtree 解题报告 (C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS 日期 题目地址:https://leetcod ...

  9. 【九度OJ】题目1207:质因数的个数 解题报告

    [九度OJ]题目1207:质因数的个数 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1207 题目描述: 求正整数N(N& ...

  10. treecnt 算法马拉松20(告别美国大选及卡斯特罗)

    treecnt 基准时间限制:1 秒 空间限制:131072 KB 给定一棵n个节点的树,从1到n标号.选择k个点,你需要选择一些边使得这k个点通过选择的边联通,目标是使得选择的边数最少. 现需要计算 ...