注意修改了这些config后,需要exit后才能生效
git config --global core.editor "vim"
git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.st status
git config --global alias.br branch
git config --global alias.hist 'log --graph --format=format:"%C(red)%h%C(reset) %C(yellow)%ad%C(reset) | %s %C(green)\[%an\]%C(reset)%C(bold blue)%d%C(reset)" --abbrev-commit --date=short'
git config --global alias.root 'rev-parse --show-toplevel'
git config --global alias.alias '!git config --global --list | grep ^alias'
git config --global alias.head 'rev-list -n1 --abbrev-commit HEAD'
git config --global color.ui auto
git config --global -l 可以查看我的配置
$ git checkout -b dev #Switched to a new branch 'dev'
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev #创建 branch dev
$ git checkout dev #Switched to branch 'dev'
$ git branch命令会列出所有分支,当前分支前面会标一个*号。
$ git add readme.txt
$ git commit -m "branch test"
现在,dev分支的工作完成,我们就可以切换回master分支:
$ git checkout master #Switched to branch 'master'
$ git merge dev #把dev分支的工作成果合并到master分支上
git checkout -- file可以丢弃工作区的修改
git merge命令用于合并指定分支到当前分支。合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。
注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度非常快。
当然,也不是每次合并都能Fast-forward,我们后面会讲其他方式的合并。
合并完成后,就可以放心地删除dev分支了:
$ git branch -d dev #Deleted branch dev.
删除后,查看branch,就只剩下master分支了:
$ git branch
* master
因为创建、合并和删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。
Git鼓励大量使用分支:
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
注意:切换分支前需要提交修改的代码,然后再切换分支,不然会丢失工作区代码修改
$ git add readme.txt
$ git commit -m "branch test"
$ git add test.txt
$ git commit -m "add test.txt"
提交了过后再删除文件这样,如果没有提交可以直接rm file来删除添加的文件
$ git rm test.txt删除文件
$ git commit -m "remove test.txt"#把删除的提交上去
git log --graph命令可以看到分支合并图
git log --graph --pretty=oneline --abbrev-commit
gitk
在gerrit上如何cherry pick代码
--------[cherry-pick]---------------------
git cherry-pick <commit id>
------------<cherry-pick Conflict>-------------------
git mergetool
git cherry-pick --continue
cherrypick 相关的命令
------------[rebase Conflict]--------------------
git mergetool
git rebase --continue
# 删除 untracked files
git clean -f
# 连 untracked 的目录也一起删掉
git clean -fd
# 连 gitignore 的untrack 文件/目录也一起删掉 (慎用!一般这个是用来删掉编译出来的 .o之类的文件用的)
git clean -xfd
# 在用上述 git clean 前,建议加上 -n 参数来先看看会删掉哪些文件,防止重要文件被误删
git clean -nxfd
git clean -nf
git clean -nfd
--------[cherry-pick]---------------------
git cherry-pick <commit id>
----------- [ set yoursream: Master ]---------------------
git br --set-upstream-to origin/master
--------[ git show ]---------------------
git show <commit-id>
--------[ untracked files ]---------------------
git clean -f
--------[ untracked ]---------------------
git clean -fd
--------[ gitignore untrack ]---------------------
git clean -xfd
--------[ git clean ]---------------------
git clean -nxfd
git clean -nf
git clean -nfd
--------[hard commit-id]---------------------
git reset --hard commit-id
??:git reset --hard ca50b7be070
--------[revert commit]---------------------
git revert <commit-id>
git revert ca50b7be070
--------[update]---------------------
git reset HEAD^
git co commit-id
git co -b xxxxx
git st
git hist #可以查看提交历史,提交序列号
git show 7a197535ebc --name-only 看这个版本提交了什么文件
git show 7a197535ebc tools/scripts/misc/coding_guidelines_checker.py
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
git reset --soft HEAD^
git log -5
commit xxxxxxxxxxxxxxx 会看到这行ID号
git reset --hard commit_id //退到/进到 指定commit的sha码