1. 软件开发中,总有无穷无尽的新的功能要不断添加进来。
    2. 添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。
    3. 现在,你终于接到了一个新任务:开发代号为Vulcan的新功能,该功能计划用于下一代星际飞船。
    4. 于是准备开发:
    5. $ git checkout -b feature-vulcan
    6. Switched to a new branch 'feature-vulcan'
    7. 5分钟后,开发完毕:
    8. $ git add vulcan.py
    9. $ git status
    10. # On branch feature-vulcan
    11. # Changes to be committed:
    12. # (use "git reset HEAD <file>..." to unstage)
    13. #
    14. # new file: vulcan.py
    15. #
    16. $ git commit -m "add feature vulcan"
    17. [feature-vulcan 756d4af] add feature vulcan
    18. 1 file changed, 2 insertions(+)
    19. create mode 100644 vulcan.py
    20. 切回dev,准备合并:
    21. $ git checkout dev
    22. 一切顺利的话,feature分支和bug分支是类似的,合并,然后删除。
    23. 但是,
    24. 就在此时,接到上级命令,因经费不足,新功能必须取消!
    25. 虽然白干了,但是这个分支还是必须就地销毁:
    26. $ git branch -d feature-vulcan
    27. error: The branch 'feature-vulcan' is not fully merged.
    28. If you are sure you want to delete it, run 'git branch -D feature-vulcan'.
    29. 销毁失败。Git友情提醒,feature-vulcan分支还没有被合并,如果删除,将丢失掉修改,如果要强行删除,需要使用命令git branch -D feature-vulcan
    30. 现在我们强行删除:
    31. $ git branch -D feature-vulcan
    32. Deleted branch feature-vulcan (was 756d4af).
    33. 终于删除成功!
    34. 小结
    35. 开发一个新feature,最好新建一个分支;
    36. 如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除。