百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

git的撤销、删除和版本回退

wptr33 2025-01-16 21:12 19 浏览

备注:


本文参考于廖雪峰的博客Git教程。依照其博客进行学习和记录,感谢其无私分享,也欢迎各位查看原文。


知识点:


1、git status,查看git仓库的状态


2、git diff 查看git修改了的内容


3、HEAD指向的版本就是当前版本,使用git reset --hard commit_id命令可以回到指定版本


4、通过git log查看提交历史和git reflog查看命令历史,确定回退或恢复到某一版本。


查看git仓库的状态


我们修改一下readme文件的内容,添加一行内容。


  • 运行git status查看状态


liu@liu-virtual-machine:~/gitTest$ git status
位于分支 master
尚未暂存以备提交的变更:
  (使用 "git add <文件>..." 更新要提交的内容)
  (使用 "git checkout -- <文件>..." 丢弃工作区的改动)

	修改:     readme.txt

修改尚未加入提交(使用 "git add" 和/或 "git commit -a")


git status命令可以查看仓库当前的状态,上面显示,readme.txt文件被修改过,但还没有加入提交修改的内容。


  • git diff可以查看修改了什么内容,这样就可以清楚的知道上次修改的内容是什么,如下


liu@liu-virtual-machine:~/gitTest$ git diff
diff --git a/readme.txt b/readme.txt
index 90269eb..7d0ff65 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,4 +1,4 @@

 `this is a test that I learning and use git version control system
 this is a beginning
-wofaidognyixie dognxi
+i Add a new line information in the end of readme.txt file


在修改最后一行之前我添加和提交了一行wofaidognyixie dognxi,现在修改为i Add a new line information in the end of readme.txt file,相当于删除添加。git diff查看不同的内容,结果显示出修改前后的对比。


  • git add readme.txt添加修改,此时查看仓库状态,提示:要提交的变更为readme.txt


liu@liu-virtual-machine:~/gitTest$ git status
位于分支 master
要提交的变更:
  (使用 "git reset HEAD <文件>..." 以取消暂存)

	修改:     readme.txt


  • git commit和git status提交并查看当前仓库状态


liu@liu-virtual-machine:~/gitTest$ git commit -m "add a new line in readme.txt"
[master e181953] add a new line in readme.txt
 1 file changed, 1 insertion(+), 1 deletion(-)
liu@liu-virtual-machine:~/gitTest$ git status
位于分支 master
无文件要提交,干净的工作区


显示没有需要提交的修改,干净的工作区,(working directory clean)


查看历史记录。


对于版本控制系统,重要的是我们可以查看历史记录,方便我们知道每次修改和提交的内容。


  • git log查看修改历史


git log显示从最近到最远的提交日志,每一次提交的作者、日期和提交的信息都被显示出来。


  • 如果显示信息太多,可加上--pretty-oneline


liu@liu-virtual-machine:~/gitTest$ git log --pretty=oneline
e181953c3f43e15ceee10fb86f05fd4568265127 add a new line in readme.txt
1769dcb57a1b16d3c4ed7f96828af2f1131f5882 modify
d5b84bff04a672d9f520334d42e71a3e79910f17 modifya readme file
3033dda882f53ea249d6dacd4c39c470fab700e8 add a readme file


此时每条log记录被显示在一行。


每行前面的一串字母数字是commit id(版本号)。和svn不一样,Git的commit id不是1,2,3递增数字,而是一个SHA1计算出来的一个非常大的数字,16进制表示.为什么commit id需要用这么一大串数字表示呢?因为Git是分布式的版本控制系统,后面我们还要研究多人在同一个版本库里工作,如果大家都用1,2,3……作为版本号,那肯定就冲突了。


Git将每一次提交串成一条时间线。


版本回退


  • git首先需要知道当前版本是哪个版本。


Git中,用HEAD表示当前版本,即上面最新提交的e181...5127,上一个版本就是HEAD^,上上个版本使HEAD^^,当往上100个版本时,写成HEAD~100


  • git reset --hard HEAD^


将当前版本“add a new line in readme.txt”回退到上一版本“modify”,如下:


iu@liu-virtual-machine:~/gitTest$ git reset --hard HEAD^
HEAD 现在位于 1769dcb modify


查看readme.txt的内容已经是modify版本,


此时用git log查看历史记录


liu@liu-virtual-machine:~/gitTest$ git log
commit 1769dcb57a1b16d3c4ed7f96828af2f1131f5882
Author: findmoon <1286637198@qq.com>
Date:   Tue Feb 20 13:37:05 2018 +0800

    modify

commit d5b84bff04a672d9f520334d42e71a3e79910f17
Author: findmoon <1286637198@qq.com>
Date:   Tue Feb 20 12:55:06 2018 +0800

    modifya readme file

commit 3033dda882f53ea249d6dacd4c39c470fab700e8
Author: findmoon <1286637198@qq.com>
Date:   Tue Feb 20 12:48:53 2018 +0800

    add a readme file


之前的最新版本记录已经没有。要想重新回到原来的最新版本,你需要记下当时的版本号(终端不关闭,可以向上找到)。如“add a new line in readme.txt”版本的commit id e18195...


  • 指定前进到未来某一版本


liu@liu-virtual-machine:~/gitTest$ git reset --hard e181953c3f43e15ceee10fb86f05fd4568265127
HEAD 现在位于 e181953 add a new line in readme.txt


readme.txt内容已经变为最新版本。


  • git reset --hard e181953可以不必将版本号写全,Git会自动查找


Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针,当回退版本时,Git仅仅是把HEAD从指向当前版本,改为指向回退的版本.然后把工作区的文件更新。


  • 当回退到某一版本后又想恢复到最新版本,就必须找到commit id。Git提供it reflog记录你的每一次命令


liu@liu-virtual-machine:~/gitTest$ git reflog
1769dcb HEAD@{0}: reset: moving to HEAD^
e181953 HEAD@{1}: reset: moving to e181953c3f43e15ceee10fb86f05fd4568265127
1769dcb HEAD@{2}: reset: moving to HEAD^
e181953 HEAD@{3}: commit: add a new line in readme.txt
1769dcb HEAD@{4}: commit: modify
d5b84bf HEAD@{5}: commit: modifya readme file
3033dda HEAD@{6}: commit (initial): add a readme file


通过每一条命令历史前面的commit id,就可以恢复想要的版本。

相关推荐

十年之重修Redis原理(redis重试机制)

弱小和无知并不是生存的障碍,傲慢才是。--------面试者...

Redis 中ZSET数据类型命令使用及对应场景总结

1.zadd添加元素zaddkeyscoremember...

redis总结(redis常用)

RedisTemplate封装的工具类packagehk.com.easyview.common.helper;importcom.alibaba.fastjson.JSONObject;...

配置热更新系统(如何实现热更新)

整体设计概览┌────────────┐┌────────────────┐┌────────────┐│配置后台服务│--写入-->│Red...

java高级用法之:调用本地方法的利器JNA

简介JAVA是可以调用本地方法的,官方提供的调用方式叫做JNI,全称叫做javanativeinterface。要想使用JNI,我们需要在JAVA代码中定义native方法,然后通过javah命令...

SpringBoot:如何优雅地进行响应数据封装、异常处理

背景越来越多的项目开始基于前后端分离的模式进行开发,这对后端接口的报文格式便有了一定的要求。通常,我们会采用JSON格式作为前后端交换数据格式,从而减少沟通成本等。...

Java中有了基本类型为什么还要有包装类型(封装类型)

Java中基本数据类型与包装类型有:...

java面向对象三大特性:封装、继承、多态——举例说明(转载)

概念封装:封装就是将客观的事物抽象成类,类中存在属于这个类的属性和方法。...

java 面向对象编程:封装、继承、多态

Java中的封装(Encapsulation)、继承(Inheritance)和多态(Polymorphism)是面向对象编程的三大基本概念。它们有助于提高代码的可重用性、可扩展性和可维护性。...

怎样解析java中的封装(怎样解析java中的封装文件)

1.解析java中的封装1.1以生活中的例子为例,打开电视机的时候你只需要按下开关键,电视机就会打开,我们通过这个操作我们可以去间接的对电视机里面的元器件进行亮屏和显示界面操作,具体怎么实现我们并不...

python 示例代码(python代码详解)

以下是35个python代码示例,涵盖了从基础到高级的各种应用场景。这些示例旨在帮助你学习和理解python编程的各个方面。1.Hello,World!#python...

python 进阶突破——内置模块(Standard Library)

Python提供了丰富的内置模块(StandardLibrary),无需安装即可直接使用。以下是一些常用的内置模块及其主要功能:1.文件与系统操作...

Python程序员如何调试和分析Python脚本程序?附代码实现

调试和分析Python脚本程序调试技术和分析技术在Python开发中发挥着重要作用。调试器可以设置条件断点,帮助程序员分析所有代码。而分析器可以运行程序,并提供运行时的详细信息,同时也能找出程序中的性...

python中,函数和方法异同点(python方法和函数的区别)

在Python中,函数(Function)...

Python入门基础命令详解(python基础入门教程)

以下是Python基本命令的详解指南,专为初学者设计,涵盖基础语法、常用操作和实用示例:Python基本命令详解:入门必备指南1.Python简介特点:简洁易读、跨平台、丰富的库支持...