查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
在实际开发中,我们应该按照几个基本原则进行分支管理:
-
master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活
-
在dev分支上进行开发,也就是说,dev分支是不稳定的,到版本发布时,再把dev分支合并到master上,在master分支发布版本
-
你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。
-
如果有中间版本,比如测试版,预发布版,按照优先级和流程,从dev递归合并到master上。
-
合并分支时,加上
--no-ff
参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
$ git branch <branchname>
all branch
$ git branch
$ git checkout <branchname>
$ git checkout -b <branchname>
$ git merge <branchname>
$ git branch -d <branchname>
$ git branch -D <branchname>
当Git无法自动合并分支时,就必须首先解决冲突。 解决冲突后,才可以继续操作。
$ git log --graph
为什么要敲这么长的命令呢?因为树很长,而简版一眼可以看穿架构
git log --graph --pretty=oneline --abbrev-commit
因为本次合并要创建一个新的commit,所以加上-m
参数,把commit描述写进去。
合并分支时,加上--no-ff
参数就可以用普通模式合并,能看出来曾经做过合并,包含作者和时间戳等信息,而fast forward合并就看不出来曾经做过合并。
$ git merge --no-ff -m "description" <branchname>
$ git stash
$ git stash list
但是恢复后,stash内容并不删除,你需要手动删除
git stash apply
git stash drop
git stash pop
git stash apply <stash version>
$ git branch -D <branchname>
$ git remote -v
建议本地和远程分支的名称保持一致
$ git checkout -b branch-name origin/branch-name,
$ git branch --set-upstream branch-name origin/branch-name;
设置为跟踪来自origin 的远程分支branch-name。
使用 --track 或 --set-upstream-to 分支 origin/branch-name
$ git branch --track branch-name origin/branch-name;
如果推送失败,先用git pull
抓取远程的新提交;
$ git push origin branch-name
如果有冲突,要先处理冲突。
$ git pull