软件开发中,总有无穷无尽的新的功能要不断添加进来。

添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。

现在,你终于接到了一个新任务:开发代号为Vulcan的新功能,该功能计划用于下一代星际飞船。

于是准备开发:

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

5分钟后,开发完毕:

$ git add vulcan.py
$ git status
# On branch feature-vulcan
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# new file: vulcan.py
#
$ git commit -m "add feature vulcan"
[feature-vulcan 756d4af] add feature vulcan
1 file changed, 2 insertions(+)
create mode 100644 vulcan.py

切回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分支还没有被合并,如果删除,将丢失掉修改,如果要强行删除,需要使用命令git branch -D feature-vulcan

现在我们强行删除:

$ git branch -D feature-vulcan
Deleted branch feature-vulcan (was 756d4af).

终于删除成功!

 

小结

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

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

最新文章

  1. Backbone事件模块及其用法
  2. 你也可以当面霸-Servlet与JSP的原理及特点
  3. ibatis的iterate使用
  4. c++ const 关键字 学习笔记
  5. Tomcat环境变量的配置
  6. SublimeText的使用
  7. win7下使用git
  8. css关键字unset
  9. 201521044091 《Java程序设计》第12周学习总结
  10. Codeforces Round #436 (Div. 2) D. Make a Permutation!
  11. json数组,前后端传值问题,与data时间转毫秒
  12. Ubuntu 安装 Docker CE
  13. LSTM学习—Long Short Term Memory networks
  14. ML.NET 示例:二元分类之垃圾短信检测
  15. rails render
  16. 最小树形图(hdu4966多校联赛9)
  17. iOS: NSObject中执行Selector的相关方法
  18. 爬虫开发12.selenium在scrapy中的应用
  19. mongoDB使用小记
  20. .NET C#生成随机颜色,可以控制亮度,生成暗色或者亮色 基于YUV模式判断颜色明亮度

热门文章

  1. jQuery-选择器-查找标签
  2. 十、springboot之web开发打包生产
  3. SQLAlchemy-对象关系教程ORM-一对多(外键),一对一,多对多
  4. js权威指南---学习笔记02
  5. 20155225 2016-2017-2 《Java程序设计》第十周学习总结
  6. Python3中的yield from语法
  7. Factroy 简单工厂
  8. Python全栈开发之目录
  9. Zookeeper服务器集群的搭建与操作
  10. mysql find_in_set函数详解