你一定使用过Word,当你做了一些修改后,又后悔了,想要回到原来的状态,你只需要点击【撤销】按钮或者使用快捷键Ctrl + z就行了。
在Git中就提供了一个这样的功能。
你已经知道git commit可以向仓库提交了,事实上你的每次提交都相当于保存了一个快照,今后,如果你后悔了,想要回退到原来的版本,只要找到原来版本的快照就可以了。
那怎么才能知道我保存了哪些快照呢?
这里有一个很简单的命令:
git log
举个例子:
$ git log
commit efce86079aec759d9299adbfdfbb8901da7e36cc
Author: qiao <test@test.com>
Date: Sun Mar 20 12:39:30 2016 +0800
add very
commit c33825b574c6cf8188a5894876a73ad1bd8b2411
Author: qiao <test@test.com>
Date: Sun Mar 20 12:37:59 2016 +0800
great became amazing
commit eb5187511f6dbee54a2d417001ba4137512c00ef
Author: qiao <test@test.com>
Date: Sun Mar 20 12:35:30 2016 +0800
add readme.md
git log 命令给出了你的每一次提交,并按时间顺序依次显示,非常详细。但是有时候你只想要一个简单的结果,可以试试这个参数:
$ git log --pretty=oneline
efce86079aec759d9299adbfdfbb8901da7e36cc add very
c33825b574c6cf8188a5894876a73ad1bd8b2411 great became amazing
eb5187511f6dbee54a2d417001ba4137512c00ef add readme.md
显示的结果的前面是一串乱码一样的东西那是commit id,后面是提交时的说明。
好了,我已经知道历史了。
但是我现在后悔了,我想回去怎么办?
在Git中,有个指针,叫做HEAD,HEAD指向哪个快照,你现在就在哪个状态。
默认HEAD指针指向最近一次的快照,如果我想让它指向上一次怎么办?很简单,HEAD指向当前,HEAD指向HEAD的上一个快照,HEAD^指向HEAD的上上一个状态,以此类推。往上很多个版本有简便写法HEAD~100。
现在我们就要回到上一个版本了。这里有一个命令:
git reset
$ git reset --hard HEAD^
HEAD is now at c33825b great became amazing
Git告诉你已经回到了“great became amazing”这个版本了。
现在你又后悔了,想重新回到“add very”这个版本怎么办?
很简单,你只要知道"add very"的commit id就可以了。所以你理所当然的使用git log查看commit id:
$ git log --pretty=oneline
c33825b574c6cf8188a5894876a73ad1bd8b2411 great became amazing
eb5187511f6dbee54a2d417001ba4137512c00ef add readme.md
咦?"add very"不见了!
记住,git log只能查看HEAD及HEAD以前的版本。
但是你有真的很想回去,有办法:
git reflog
这个命令可以查看所有操作命令:
$ git reflog
c33825b HEAD@{4}: reset: moving to HEAD^
efce860 HEAD@{5}: commit: add very
c33825b HEAD@{6}: commit: great became amazing
eb51875 HEAD@{7}: commit (initial): add readme.md
这时你就知道了“add very”的commit id了,你就可以很开心的回去了:
$ git reset --hard efce860
HEAD is now at efce860 add very
Git告诉你,HEAD指针又重新指向“add very了”。
如果喜欢的话,可以关注我的微博http://weibo.com/qiaoer2017