git 使用总结

gitlab docker 镜像

$ git clone --depth 1 --recursive https://github.com/Valloric/YouCompleteMe.git

OR

$ git clone https://github.com/Valloric/YouCompleteMe.git
$ cd crfasrnn
$ git submodule update --init --recursive

子模块

http://stackoverflow.com/questions/2144406/git-shallow-submodules

  1. 添加子模块
$ git submodule add 仓库地址 路径
  1. 删除子模块
  2. 状态
$ git submodule status
  1. 更新子模块
$ git submodule update --init --recursive
$ git submodule add url path/to/name
$ git submodule init
$ git submodule foreach git pull
$ git submodule update
  1. 同步一个COMMIT

    可以同步一个commit到本分支

$ git cherry-pick xxx
  1. Git打TAG

打TAG也就是发布版本


$ git tag -a v1.2 -m “version 1.4” $ git push –tags 如果还不能理解可以到这里看看是linus是怎么给Linux内核打的TAG,TAG看起来像什么:https://github.com/torvalds/linux/releases

# .查看status详情

这样可以在commit之前先看一下修改详情。

$ git add xxx
$ git diff --cached

# .不产生无用的merge的同步 有这么一种情况,用一个分支专门同步代码提供商的代码的时候,如果一般的pull会不断的产生一个merge看起来会很烦,用下边的使用添加一个–rebase就不会产生无用的merge了

$ git pull --rebase origin master

# .关于stash 适用情况:做了修改后,还没有add commit等等后续工作,现在突然要切换分支做其它事情,默认情况下你在这个分支修改的代码会被带到切换过去的分支中。可以先把你修改的保存起来。这些修改可以再还原过来。

$ git stash -u

$ xxxx 随便你的操作
$ git stash pop

注意:-u是代表是也把添加的新文件(术语是未跟踪)也藏起来,一般是要有这个u的。

# .恢复一个COMMIT
如果一个COMMIT你不想要了,想要去除,可以考虑使用以下的方法;
$ git revert xxxx

这个就可以去掉这个COMMIT的改动,这个是明式的去掉,如果你又后悔了,还可以再次恢复。