`
foo
  • 浏览: 25077 次
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

软件工厂是否真的可能存在?

阅读更多

一点说明:作为程序员,通常心里是讨厌软件工厂的,但很多时候问题自身皆有其内在理性,并不以个人的偏好而改变其发展的轨迹。

所以程序员一旦谈及和自身喜好相关的问题时,尤其要摒绝个人好恶,否则就会离问题的真相越来越远,而只有一腔情绪。

 

 

就我个人观察软件工厂大致处在这样一种地位:经营管理者迫于成本的压力,总是潜在的期望其可能实现;而程序员群体自身则总是对其嗤之以鼻。

 

 

为什么在经营层面软件工厂有如此大的诱惑力?

 

这不难理解,如果软件可以用工厂的模式来运作,那么程序员的可替换性将被无限强化,这样软件开发的成本就可以大幅度降低。

看看近二十年来中国制造的影响,就可以理解这种廉价劳动力所蕴含的巨大杀伤力。

经营层面话题可以无限丰富,但永远也无法摆脱的则是永恒的利益,而这些利益又是不得不争。

外包,外协人员所有这些东西的出现貌似偶然,但终究是利益驱动。

同样的原因,很多人也总是忘不了软件工厂。

 

 

但软件工厂的方向实在是错误的,这种错误不在于口水上的是是非非,而在于使用软件工厂模式投入产出比很低,一样会照成利益上的损失,而非相反。

 

工厂的特征是按照既定的工艺流程,大批量生产同样的东西,这时候通常会有规模效益。

而软件开发是通过明确概念和逻辑来一次性的创造东西,这时候的特征是规模不经济(diseconomy of scale)。

这点是有很多工程数据可以支撑的。

 

这也就意味着,创造,创新性的东西是无法和工厂的特征相结合的,而更类似于某种工艺的确认过程。

 

 

勉强为软件开发导入工厂模式时,很多人会努力切分想(设计)和做(编码)。

这里的问题在于软件开发中想和做是无法切的干净利落的,想约定了做的方向,但做的过程中必然带着对想的深化。

 

对于全新的开发,不管需求分析还是架构设计都很难摆脱迭代的特征,这个时候需要的是全员参与及积极的沟通。

独裁体制会阻塞这种信息回路,进而降低效率。

 

 

我们可以用一个很简单的公式来做些推导:

 

 生产率:Productivity =  Scale/MM  单位:KSLOC/MM

其中,Scale代表最终软件产品的规模,我们用代码行来做度量规模的单位。

MM则是开发此软件产品所花费的人月。

而与此同时,Scale = Coding Speed *Coding MM。

 

Coding Speed是指一个程序员编写代码的速度(不是指生产率),而Coding MM则是指所有程序员 用来编码的时间。

把这两个简单的公式合在一起,生产率的公式将变为:

 

Productivity =  Coding Speed* CodingMM/Total MM  单位:KSLOC/MM

如果我们假设Coding Speed是一个程序员写出Bug最少,质量最佳代码的时间,那么显然生产率主要和程序员的能力以及编码所投入的时间有关。

而软件工厂模式恰恰与此相反,编码速度较低,耗费在沟通上时间会多,所以生产率大致上是低的。

 

 

顺道一提:李开复先生的公司叫创新工厂,这很有意思,从本质上看,专注创新的一定不是工厂,而工厂的使命也一定不主要是创新。

这是一个充满矛盾的名字,只是不知道从何而来。

分享到:
评论

相关推荐

    抽象工厂模式(Abstract Factory Pattern)

    咱们假设一种情况(现实中是不存在的,要不然,没法进入共产主义了,但有利于说明抽象工厂模式),在你的家中,某一个衣柜(具体工厂)只能存放某一种这样的衣服(成套,一系列具体产品),每次拿这种成套的衣服时也自然...

    软件设计规范

    架构是否存在?如果我们所说非虚,那么如何为架构下一个定义-一定是一个由具体业务流量和模式支撑的架构) 软件(算法)的构造。一个是数据的复杂性(内在互相关系),一个是计算方法(步骤和缓冲)。从宏观角度,...

    从实例谈面向对象编程、工厂模式和重构

    可能还会有人问,即使你使用这种方式,那么在判断具体创建哪个工厂的时候,不是也要用到 switch 语 句吗?我承认这种看法是对的。不过使用工厂模式,其直接好处并非是要解决switch 语句的难题,而是 要延迟对象的...

    从模式讲到设计模式再到面向对象设计模式

    在20世纪90年代,软件界有好多人在想,软件开发中是否存在以某种相同的方式解决不断重复出现的问题,是否可以用模式的方法来设计软件,经过他们不断的总结,答案是肯定的。  以现实生活中“路”的生成为例:...

    基于客户端驱动型工厂模式设计的券商客户端自动化交易python程序,它具备了支持所有券商客户端及其未来版本的能力(python)

    自动化软件测试受内外环境的影响较大,该项目以最大的可能减少内外环境的变化对软件自动化的影响。 由于采用“客户端驱动型工厂模式”,所以项目可扩展性高、可根据不同的券商版本制作不同的交易模型也可以制作不同...

    moto 3688写频软件

    解决了不同版本codeplug复制过程中存在的错误。 支持对讲机GM3188和GM3688的附加频段。 R02.01 修改了对讲机GM3188和GM3688发射功率的计算方法。 R02.00 支持对讲机GP3688和GM3688。 支持不同版本...

    动软安装软件三层架构

    1. 完善了单类结构中非SQL数据库可能存在“@”,括号"[" 和 "]的问题 2. 完善了“GetList”方法缺少三参数重载。 3. 完善了浏览数据库数据报错的问题。 4. 数据库名和表实现按名称排序。 5. 页面代码生成包含主键的...

    二十三种设计模式【PDF版】

    主要是介绍各种格式流行的软件设计模式,对于程序员的进一步提升起推进作用,有时间可以随便翻翻~~ 23种设计模式汇集 如果你还不了解设计模式是什么的话? 那就先看设计模式引言 ! 学习 GoF 设计模式的重要性 ...

    WIN XP蓝屏代码大全

    (5)如果是在关闭某个软件时出现的:很有可能时软件本省存在设计缺陷, 请升级或卸载它. 5、0x00000023:FAT_FILE_SYSTEM 0x00000024:NTFS_FILE_SYSTEM ◆错误分析:0x00000023通常发生在读写FAT16或者FAT32文件系统的...

    电脑蓝屏对照码

    (5)如果是在关闭某个软件时出现的:很有可能时软件本省存在设计缺陷, 请升级或卸载它. 5、0x00000023:FAT_FILE_SYSTEM 0x00000024:NTFS_FILE_SYSTEM ◆错误分析:0x00000023通常发生在读写FAT16或者FAT32文件系统的...

    Token-Factory:基本令牌工厂dapp

    代币工厂令牌工厂允许在以太坊上轻松创建标准ERC20令牌。 它需要注入的web3(Mist或Metamask)才能起作用。 它还具有uPort支持。 目前,它不使用链上工厂。 免责声明:这是部分内置的应用程序,因此我也可以学习...

    Free barcode

    有工厂用户要输出流水条码的、有商家用户要输出条码商品标签的、有印刷行业的用户要输 出特别的格式,等等,各行各业,五花八门的拥上来咨询、请教、提要求。在此作者声明:本软件作者对 FreeBarcode 软件,不提供...

    吉林大学软件学院卓班设计模式第二次作业

    请试一试将重载的构造函数改成(简单)工厂方法,使得语义更清晰。 3. 考察完成的代码,你会发现: a) 在构造、拷贝、赋值时,会将各子图都重新构造了一遍,拷贝和赋值使用的也是深拷贝和深赋值,这样在合成复杂的字符...

    超级有影响力霸气的Java面试题大全文档

    例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。 当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望...

    LINGO软件的学习

    #eq#是逻辑运算符,用来判断是否“相等”,可参考§4. &1可看作派生集的第1个原始父集的索引,它取遍该原始父集的所有成员;&2可看作派生集的第2 个原始父集的索引,它取遍该原始父集的所有成员;&3,&4,……,...

    java 面试题 总结

    声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以创建一个变量,其...

    条形码生成FreeBarcode

    有工厂用户要输出流水条码的、有商家用户要输出条码商品标签的、有印刷行业的用户要输 出特别的格式,等等,各行各业,五花八门的拥上来咨询、请教、提要求。在此作者声明:本软件作者对 FreeBarcode 软件,不提供...

    PetShop4.0宠物商店+系统架构设计+中文注释源码+PDF中文详解

    16、 OrderInfo.cs文件:用于显示用户某一个订单具体信息的类,在此一个订单当中,可能包括多个商品种类,即包括多个LineItemInfo对象(实际上在OrderInfo类中也确实存在LineItemInfo类型对象的一个数组!...

    FreeBarcode

    有工厂用户要输出流水条码的、有商家用户要输出条码商品标签的、有印刷行业的用户要输 出特别的格式,等等,各行各业,五花八门的拥上来咨询、请教、提要求。在此作者声明:本软件作者对 FreeBarcode 软件,不提供...

Global site tag (gtag.js) - Google Analytics