Skip to content

Latest commit

 

History

History
209 lines (127 loc) · 3.62 KB

branch.md

File metadata and controls

209 lines (127 loc) · 3.62 KB

分支

常用分支命令

查看分支:git branch

创建分支:git branch <name>

切换分支:git checkout <name>

创建+切换分支:git checkout -b <name>

合并某分支到当前分支:git merge <name>

删除分支:git branch -d <name>

分支策略

在实际开发中,我们应该按照几个基本原则进行分支管理:

  1. master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活

  2. 在dev分支上进行开发,也就是说,dev分支是不稳定的,到版本发布时,再把dev分支合并到master上,在master分支发布版本

  3. 你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

  4. 如果有中间版本,比如测试版,预发布版,按照优先级和流程,从dev递归合并到master上。

  5. 合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。

创建分支

$ git branch <branchname>

查看本地分支

all branch

$ git branch

查看远程分支

r=remote

$ git branch -r

查看所有分支

a=all

$ git branch -a

切换分支

$ 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

普通模式合并分支:禁用no-ff

因为本次合并要创建一个新的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