首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Git 第10课】 版本回退

【Git 第10课】 版本回退

作者头像
Crossin先生
发布2018-04-16 15:00:21
7210
发布2018-04-16 15:00:21
举报

昨天关于 PyCon 的介绍里有个小bug,北京场是14日,和其他分会场不是同一天。特此更正,北京的小伙伴们请注意。

----------------

上次说到,如果你已经提交了代码,但是又后悔了,想要放弃这次的改动,回到之前的版本。这时候就需要做版本回退。

我们先在工作目录中运行 git log 命令,看看到目前为止的提交记录:

commit 81e34d1d269b13bb23619d828495119492eabc5a

Author: Crossin

Date: Thu Nov 28 17:27:34 2013 +0800

remove file

commit 1edcbf15f45359768b3fa9cd99ddddde792912fe

Author: Crossin

Date: Thu Nov 28 15:16:37 2013 +0800

add file to be deleted

commit 15547cb5e6bb661a4b9934c1ea55fe0aeceb0682

Author: Crossin

Date: Tue Nov 26 14:39:06 2013 +0800

test file status

commit c1310cffd37c4b7fe765986035e54a3c27c2887f

Author: Crossin

Date: Tue Nov 26 14:11:46 2013 +0800

init readme

也许你的提交历史和我不一样,这没关系。

还记得我们前面课里说过的 HEAD,它指向的是最新的提交。而上一次的提交就是 HEAD^,上上次是 HEAD^^,也可以写成 HEAD~2,以此类推。之前30次版本就是 HEAD~30,或者你愿意也可以打30个^。

要回退上一个版本,只要:

git reset --hard HEAD^

--hard 表示放弃所有的本地改动,其他的可选模式我们先不管。

输出提示:

HEAD is now at 1edcbf1 add file to be deleted

HEAD 已经被移动回“add file to be deleted”这个版本。

如果想要移动到某个指定的提交,也可以直接使用提交id,就是 git log 里,commit 后面的一串字符(你的版本中的提交 id 和我是不一样的)。

git reset --hard 15547

id 不用输全,前几位就够,git 会自动去找匹配的提交。然后就可以看到:

HEAD is now at 15547cb test file status

顺便说一下,你可以使用 git 里自带的图形化客户端 gitk 来查看和管理版本变动。在命令行里输入 gitk,mac 上是 gitx,就可以打开(如果不幸没有打开,可能你需要另行安装以下)。

回退前:

回退后:

注意,当用 git reset --hard 回退版本后,所有的本地未提交改动将被舍弃,而被回退掉的版本也不再出现在记录里(虽然还是可以被找回来)。所以在使用此操作时请慎重考虑。

#==== Crossin的编程教室 ====#

每天5分钟,轻松学编程

回复 p 查看Python课程

回复 g 查看Pygame课程

回复 i 查看Git课程

回复 t 查看习题

回复 w 查看其他文章

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2013-12-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Crossin的编程教室 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档