在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. Linux中find命令与三剑客之grep和正则

    昨日内容回顾 1.每个月的3号.5号和15号,且这天时周六时 执行 00 00 3,5,15 * 6 2.每天的3点到15点,每隔3分钟执行一次 */3 3-15 * * * 3.每周六早上2点半执行 ...

  2. CF1520D Same Differences 题解

    Content 给定 \(n\) 个数 \(a_1,a_2,\dots,a_n\),求有多少个二元组 \((i,j)\) 满足: \(i<j\). \(a_j-a_i=j-i\). 数据范围:\ ...

  3. LuoguB2105 矩阵乘法 题解

    Content 给定一个 \(n\times m\) 的矩阵 \(A\) 和一个 \(m\times k\) 的矩阵 \(B\),求两个矩阵相乘得到的矩阵. \(n\times m\) 的矩阵 \(A ...

  4. java 网络编程基础 UDP协议的Socket:DatagramSocket;广播Socket:MulticastSocket

    什么是UDP协议: UDP协议是一种不可靠的网络协议,它在通信实例的两端各建立一个Socket 但这两个 Socket之间并没有虚拟链路,这两个Socket只是发送.接收数据报的对象.Java 提供了 ...

  5. linux查看磁盘SN

    ls -l /dev/disk/by-id/ | grep -iE   <SN>

  6. More Effective C++ 基础议题(条款1-4)总结

    More Effective C++ 基础议题(条款1-4)总结 条款1:仔细区别pointers和references 如果有一个变量,其目的是用来指向(代表)另一个对象,但是也有可能它不指向(代表 ...

  7. 钉钉提供的内网穿透之HTTP穿透

    此方法无需自行提供服务器和域名 官方地址:https://developers.dingtalk.com/document/resourcedownload/http-intranet-penetra ...

  8. SpringBoot单元测试demo

    引入maven <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...

  9. c++11之字符串格式化

    1.关于 我知道的,C++20中引入了相当方便的字符串格式化,有兴趣的朋友,可以看下fmt库,截至目前,它实现了c++20中引入的字符串格式化绝大部分功能. 2.format 既然c++11中没有方便 ...

  10. King's Order(hdu5642)

    King's Order  Accepts: 381  Submissions: 1361  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: ...