辛星浅析git中的版本回退
2015-04-19 18:03
155 查看
首先需要说的就是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时,表示最新的版本。
在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时,表示最新的版本。
相关文章推荐
- 辛星浅析git中的代码撤销与回退
- [Git高级教程 (一)] 通过Tag标签回退版本修复bug
- Git使用:版本回退
- git-【二】本地git操作提交、版本回退
- git版本回退
- git版本回退
- git各种情况的版本回退
- Git快速入门-git stash 暂存变更,git reset 撤销commit,git revert 回退远程版本库
- git回退版本(线上和本地仓库)
- [Git高级教程(二)] 远程仓库版本回退方法
- windows下git的安装、配置与操作(三)——版本回退
- git版本回退二
- Git-02_版本回退
- Git学习系列(三)版本回退和管理文件的修改及删除操作
- git远程仓库版本回退
- git远程仓库版本回退方法
- Git入门(4)-版本回退
- Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突
- git入门(5)-Git revert和git reset版本的回退
- git回退之前版本