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

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

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

备注:


本文参考于廖雪峰的博客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,就可以恢复想要的版本。

相关推荐

威信Chronosonic XVX全新旗舰全球首发 设计特点彻底公开

第一眼看到WilsonAudio新推出的ChronosonicXVX音箱,相信大家都会直觉认为它是两年前超级旗舰WAMMMasterChronosonic的缩小版,不过这个推测并不完全正确。C...

C#高精度Timer和Delay以及时间测量

在PCHMI7.0后在工具箱里会多一个MsTimer,以及Delay和Microsecond两个类。...

python教程从基础到精通,第9课—日期与时间

Hello,小伙伴们,祝大家五.一玩得快乐!刚学习完了七大数据类型,今天咱们来学习日期与时间的表示方法。Python标准库中提供了时间和日期的支持:calendar:日历相关;time、datetim...

软件测试|教你轻松玩转Python日期时间

Python基础之日期时间处理...

Go语言中互斥锁与读写锁,你知多少?

简述Golang中的锁机制主要包含互斥锁和读写锁互斥锁互斥锁是传统并发程序对共享资源进行控制访问的主要手段。在Go中主要使用sync.Mutex的结构体表示。一个简单的示例:funcmutex()...

变形金刚动画大电影——经典台词赏析

YOURDAYSARENUMBEREDNOW,DECEPTI-CREEPS你们活不了多久了,霸天虎小子。-{铁皮说的话,体现了铁皮的嫉恶如仇,可是后来铁皮在飞船上遇袭身亡,可谓是出师未捷身先...

Python时间日期模块使用教程(python3日期)

1.时间日期处理概述在日常编程中,时间日期处理是非常常见的需求,比如:记录日志时间...

亚马逊介绍AWS“无服务器”云服务改进:数据库可线上扩充容量等

IT之家11月29日消息,在今天于美国拉斯维加斯展开的亚马逊“AWSre:Invent2023”活动中,亚马逊计算部门资深副总裁PeterDeSantis,介绍了旗下三款云端服务,IT...

2.日期格式 datetime(日期时间显示格式)

fromdatetimeimportdatetime1.获取当前日期和时间now=datetime.now()#2025-05-3110:56:01.4687822.格式化日期...

【科普】时间单位大盘点(时间单位都有哪些?)

时间单位,是7种基本单位之一,长度、时间、质量、物质的量、光照度、电流和(热力学)温度是七种基本单位。本词条中时间单位以时间从大到小列。今天我们来盘点下时间的单位换算...

基于PHP的Laravel框架,盘点Github高星Web管理后台,效率为王!

在Web开发工作中,选择一个高效、稳定的后台管理系统是提高开发效率的关键。虽然PHP在近些年中的热度有所减退,但其上手简单、开源、灵活且被广泛应用的特点,仍然使其在编程语言排行榜中保持前十的位置。这表...

如何使用PHP编写一个简单的留言板?

留言板是一个常见的Web应用程序,允许用户在网站上发布和查看留言。在本文中,我们将使用PHP编写一个简单的留言板,介绍构建过程中的关键步骤和技巧。一、准备工作在开始编写留言板之前,我们需要准备好以下工...

产品经理提需求时要考虑的 15 个隐性需求

虽然世界充满未知的变化,但是有一些大的方向还是可以把握的,本文跟大家谈谈产品经理提需求时要考虑的15个隐性需求,enjoy~俗话说,计划赶不上变化快,无论需求文档做得如何细致,考虑得如何周全,总会...

关于 PHP 启动 MongoDb 找不到指定模块问题

前言:最近有一个小demo,需要通过PHP将用户行为记录储存到MongoDB,再用Spark做协同过滤。由于以前处理跨语言交互是通过消息中间件,这次本地使用MongoDB却弄出了几个问...

PHP程序员老鸟面试经历(php程序员怎么样)

在任何时代找任何工作都有面试这么一说的。特别是高端技术类的工种对技术理论和技术实操能力要求很严格。大部分公司招收技术员工的要求也越来愈高。至于PHP程序员也是如此,我估计大多数PHP老鸟已经不在意所...