辛星浅析git中的版本回退

本文介绍了Git版本控制系统中的关键概念,包括commit id的生成方式、如何使用HEAD标识当前及过往版本、利用git reset命令进行版本回退操作的方法,以及如何撤销文件修改等内容。

       首先需要说的就是commit  id,它和svn不同,git的commit id不是1,2,3...这种递增的数字,而是一个SHA1计算出来的一个非常大的数字,它用十六进制来表示,因为git是分布式的版本控制系统,所以就只能用这种方式了。

       在git中,我们用HEAD表示当前版本,上一个版本就是HEAD^,上上个版本就是HEAD^^,如果我们前100个版本就是HEAD后面跟100个^,但是我们通常不这么写,我们通常写成HEAD~100。

      而且我们回退使用git  reset命令,比如我们要回退到上一个版本,我们可以使用 git  reset   --hard   HEAD^来回退到上一个版本。

      我们可以使用git   reflog来记录我们的HEAD指向的位置,需要注意的是git  log是查看每次提交,这两个是差别很大的。

      

        而对于git  checkout  --  readme.txt,就是把readme.txt文件在工作区的修改全部撤销,这里有两种情况:

       (1)一种是readme.txt自从修改后还没有放到暂存区,那么,撤销修改就会到和版本库一模一样的状态。

        (2)一种是readme.txt已经添加到暂存区,又做了修改,那么,撤销修改就会回到暂存区后的状态。

        也就是说,git  checkout   --  文件名  就是让这个文件回到最近一次 git  commit或者git  add时的状态。

        我们还可以用命令  git  reset   HEAD  文件名   都可以吧暂存区的修改撤销掉,然后重新放回工作区。

        我们使用git  reset 命令既可以回退版本,也可以把暂存区的修改回退到工作区,我们用HEAD时,表示最新的版本。


评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值