Git的状态转换


         近期公司用Git来管理代码,用起来是要比svn爽一些。就是刚接触的时候比較痛苦,特别是那些状态(版本号的提交/合并/回退)。差点把我搞晕了。

如今回过头来总结一下,就清楚多了。

         就本地仓库来看。Git能够分成5个不同的状态。能够通过$ git status来查看。这五个状态能够互相转换。详细操作详见以下的“版本号回退/整合”。

         当然。有些文件非常实用。不能删除又不能提交,如Eclipse的项目文件. project等。

这样的情况最好就是选择把他们忽略掉,能够通过改动根文件夹的.gitignore文件,或者update-index来忽略掉。

status

         显示Git的版本号管理信息:$ git status

一般分成3个区域:

a)  Changes to becommitted:暂存区中有改动的文件,但还没commit。

b)  Changes notstaged for commit:工作区中已跟踪且有改动的文件,但还没add;

c)  Untrackedfiles:工作区中未跟踪文件。未纳入Git的管理,每一个新建的文件都属于这样的。

         从上面也能看出非常多操作的提示。

[Changes notstaged for commit]和[Untracked files]都能够通过add把文件加入到[Changes to be committed]。

另外,还能够使文件消失在Git的监控范围(ignore掉),这样status就看不到了。

         也能够使用简略的显示模式:$ git status –s

版本号回退 / 整合

         依据之前工作区/暂存区/版本号库的状态跳转图,可知道回退也是有多种情况。

 

a)     Untrack区回退

         Untrack区存放的是没有纳入Git跟踪的文件。如新创建的还没add的文件。一般Git是不会理会这部分文件的,假设你嫌碍眼,能够通过clean来清楚他们:

         先通过$ git clean –n查看要会清楚的文件,然后把n去掉,清除。也能够在后面指定文件名称,文件-f,文件夹-d

b)     工作区回退

         $ git checkout -- XXX意思是,把XXX文件在工作区的改动所有撤销:先检查暂存区有没有XXX,假设有则把工作区的XXX恢复到暂存区的状态;假设没有,则到版本号库取。

         $ git checkout . 撤销所有工作区的改动。

这个命令事实上挺危急的。一运行记录都被恢复了,改动都被丢弃了。也能够用$ gitcheckout HEAD XXX。回退暂存区和工作区。

c)      暂存区回退

         面的checkout --仅仅是撤销工作区的文件改动,假设我们想撤销暂存区的,就须要使用$ gitreset HEADXXX。它会把暂存区的记录清空掉。

我们通过$ git status就能看到Changes to be committed的内容都跑到Changes notstaged for commit中去了。

也能够用$ git checkout HEAD XXX,回退暂存区和工作区。

         对于暂存区来说。这样的方式和commit都会清空记录。前者直接清空,后者先往版本号库写。再清空。

d)     版本号库回退

         假设你不小心把脏内容commit到本地master了,上面两种方式就无效了。这时候须要回退版本号库:$ git reset--hardHEAD^

         在Git中,用HEAD表示当前版本号。上一个版本号就是HEAD^,上上一个版本号就是HEAD^^。也能够写成HEAD~2。你能够用HEAD后面加n个^。或者HEAD~n来表示回退多少个版本号。

         上面是相对版本号的reset,当然也能够指定某一个详细版本号。这时候commitID版本号号就大派用场:  $ git reset --hard3628164

3628164仅仅是版本号的前一小部分,Git会帮我们去自己主动匹配。当然也有可能找到多条。所以还是写全比較靠谱。

 

         事实上对于Git来说。HEAD是一个当前版本号号的指针,用reset来切换版本号。实际上是调整HEAD的指向。

         所以。假设你reset 到HEAD~10。还行又回去原来的HEAD,那么也能够通过【reset+ 版本号号】的方式切换过去。

         当然你要知道相应的版本号号,这时候你能够通过 $ git relog 来查看你的命令历史和相相应的版本号号

 

e)     远程版本号回退

         Git是分布式版本号控制系统,仅仅要你把内容push出去了,那么远程库就会有记录,你也不能主动改动别人的版本号,这时候就仅仅能覆盖了。

可是你干过的坏事也就公诸于世了。

 

回退merge

         假设仅仅是在merge。则能够直接回退: $ git reset--hard HEAD^

         假设merge 以后还有别的操作和改动,则能够使用revert:

$ git revert -m merge线的编号  (从1開始计算,或者merge前的版本号号)

 

★ 版本号整合

         东西已经commit了。可是又想改动,怎么办呢?能够通过上面“版本号库回退”的方法来实现:resetcommit。可是那样commit的改动就没有了,须要又一次改动,工作量大。

         所以除此之外。我们还能够:

l  假设仅仅是合并已commit的版本号:$ git rebase -i HEAD~2

l  假设有补充的改动$ git commit --amend

posted @ 2018-04-07 08:15  zhchoutai  阅读(834)  评论(0编辑  收藏  举报