码迷,mamicode.com
首页 > 其他好文 > 详细

git reset本地常见操作

时间:2015-07-21 17:05:30      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:git reset   git 回滚   git回退   


git reset命令用于将当前分支回退到指定的某个版本。

基本用法

git reset [--hard] commitversion

详解

该命令可以看做commit命令的取反操作,既然可以向前提交,当然也可以向后回滚。可以像事务一样回滚一次到上一次的位置,也可以回滚到指定的位置。这个位置由commitversion决定,每commit一次都会产生一个commitversion值。

1 --hard 选项在帮助文档中的解释是:Resets the index and working tree. Any changes to tracked files in the working tree since <commit> are discarded.

2 commitversion是指定曾经commit的版本,每次commit都会产生唯一一个commitversion,用于标识本次commit。

(1) 那么怎样找到每次commit的commitversion呢?有两个命令都可以达到这个目标:git log 和git reflog
用法分别是:
git log [--pretty=oneline]
git reflog

两者的区别是:git log查看的日志是相对于当前commitversion之前的所有历史日志,git reflog查看的日志是相对于最后一个commitversion之前的所有历史日志。展开来讲就是,一个是相对历史日志,一个是绝对历史日志。假如你已经reset到某个commitversion了,那么这个时候使用git log只能看到这个commitversion之前的历史日志,看不到之后的历史日志了,但是使用git reflog就可以。

(2) git对离当前版本最近的commitversion提供了快捷方式。
在Git中,用HEAD表示当前版本,也就是最新的提交,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
比如回退到上一个版本:git reset --hard HEAD^

扩展用法

有时工作空间的工程会由开发工具产生一些最新的文件或目录,这些文件或目录是不纳入git版本管理范围内的,所以对于电脑当前的工作空间,有时使用git reset命令在某些操作系统上不一定能完全回退,需要一个额外的操作帮助git回退,这个命令是:
git clean -dfx

用于强制清洗当前工作区不受git管理的文件或目录,帮助git将当前工作区干净的回退到指定commitversion。


版权声明:本文为博主原创文章,未经博主允许不得转载。

git reset本地常见操作

标签:git reset   git 回滚   git回退   

原文地址:http://blog.csdn.net/warhin/article/details/46987779

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!