(4.5) git分支管理-feature分支

添加一个新功能时,不想把主分支搞乱。所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。

eg:现在,加一个Vulcan的新功能,该功能计划用于下一代星际飞船。
先添加feature-vulcan分支

$ git checkout -b feature-vulcan
Switched to a new branch 'feature-vulcan'

开发完毕:

$ git add vulcan.py

$  git status
On branch feature-vulcan
Changes to be committed:
  (use "git reset HEAD ..." to unstage)

        new file:   hello.py
        new file:   vulcan.py

Changes not staged for commit:
  (use "git add ..." to update what will be committed)
  (use "git checkout -- ..." to discard changes in working directory)

        modified:   readme.md

切回dev,准备合并:

$ git checkout dev

一切顺利的话,feature分支和bug分支是类似的,合并,然后删除。

但是!

就在此时,接到上级命令,因经费不足,新功能必须取消!

虽然白干了,但是这个包含机密资料的分支还是必须就地销毁:

$ git branch -d feature-vulcan
error: The branch 'feature-vulcan' is not fully merged.
If you are sure you want to delete it, run 'git branch -D feature-vulcan'.

销毁失败。Git友情提醒,feature-vulcan分支还没有被合并,如果删除,将丢失掉修改,如果要强行删除,需要使用大写的-D参数。。

现在我们强行删除:

$ git branch -D feature-vulcan
Deleted branch feature-vulcan (was 287773e).

终于删除成功!

小结

开发一个新feature,最好新建一个分支;

如果要丢弃一个没有被合并过的分支,可以通过git branch -D 强行删除。

你可能感兴趣的:((4.5) git分支管理-feature分支)