【版本管理】git分支管理

创建与合并分支:

首先,我们创建dev分支,然后切换到dev分支:

git checkout -b dev命令加上-b参数表示创建并切换,

相当于以下两条命令:

git branch dev

git checkout dev

然后,用 git branch 命令查看当前分支。

git branch命令会列出所有分支,当前分支前面会标一个*号。

此时commit提交的就在dev分支上。

切换回master主分支 :

git checkout master,切换回master分支后,再查看刚才提交的文件,刚才添加的内容不见了!因为那个提交是在dev分支上,而master分支此刻的提交点并没有变。

现在,我们把dev分支的工作成果合并到master分支上:

git merge dev, git merge命令用于合并指定分支到当前分支。合并后,再查看文件的内容,就可以看到,和dev分支的新提交是完全一样的。

注:注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把 master指向dev的当前提交,所以合并速度非常快。 当然,也不是每次合并都能Fast-forward,我们后面会将其他方式的合并。 

合并完成后,就可以放心地删除dev分支了:git branch -d dev删除后,查看branch,就只剩下master分支了: git branch  * master。

 

解决冲突:

如果master分支和feature1分支各自都分别有新的提交,那么它们在合并时,Git无法执⾏行“快速合并”,只能试图把各自的修改合并起来,但这种合并就可能会有冲突。

git status也可以告诉我们冲突的文件。

我们需要在文件中手动修改后保存,再提交:  git add文件名git commit -m "conflict fixed",完成合并。

用带参数的git log 指令,git log --graph --pretty=oneline --abbrev-commit 查看分支的合并情况。

现在,可以再删除feature1分支:  git branch -d feature1。

 

强制禁用“Fast forward”模式:

如果要强制禁用“Fast forward”模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。

git merge --no-ff -m "merge with no-ff" dev, 因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。 

 

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

 

 

如当前分支工作到一半还不能commit,但需要切换到别的分支,Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作:

git stash,把当前工作现场“储藏”起来,然后再 git checkout master ,再 git checkout -b issue-101 在新分支上进行操作,操完后提交,切换到主分支与之合并,合并完切换回工作到一半的分支继续工作。

但切回分支后发现工作现场不在了,可先用 git stash list 查看保存的工作现场,再:

一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;

另一种方式是用git stash pop,恢复的同时把stash内容也删了。

你可以多次stash,恢复的时候,先用git stash list查看,然后恢复指定的stash,用命令: git stash apply stash@{0}

 

 

开发一个新feature,好新建一个分支; 如果要丢弃一个没有被合并过的分支,可以通过 git branch -D name 强行删除。

 

posted @ 2016-12-06 15:24  朱两边  阅读(206)  评论(0编辑  收藏  举报