软件研发之道——知识产权
知识产权
本书叙述了微软Visual C++ 开发团队的故事,通过作者的总结和归纳告诉读者如何构建一个优秀的软件开发团队,如何在一段时间内成功地交付一个软件。作为升级版,作者将言简意赅的法则扩展到57 条,包括了软件研发及营销的全部内容,相信每一位项目经理都会对此书爱不释手。
本书适合软件设计者、开发人员、营销人员及技术主管等阅读。那么,问题何在?如果按时交付优秀的软件只是取决于一些常识,又为何如此罕见呢?
考虑一下人类工作的主流模式。在大多数企业中,人们主要把资源投入到两个领域中,一个是智力活动,另一个是常规机械工作。我们可以把这两个领域看做设计和生产,或者工程设计和施工。就目前来看,企业资源(人员和资金)的最大部分通常被投入到机械工作中。汽车、建筑或高速路等工作固然包含智力内容,但工程设计上的投资在总投资中所占比例是微不足道的,尽管这部分投资具有至关重要的意义。
现在思考一下,你会如何组织一家主要从事机械工作的企业?机械工作最大的价值源于效率,因此所有元素的组织都要从效率出发。装配线是20世纪的主要工业流程,亨利·福特作为装配线的“发明者”确立了他的历史地位。装配线在一端进料,在另一端产出有形产品,它的特点是千篇一律,而且单调乏味,但具有极高的效率。装配线的进料和管理采用等级组织方式,企业中的每个人只承担一个很小且狭窄的职责。
软件开发的组织方式就完全不是这么回事了。软件开发的目标产品是知识产权,而不是有形产品,因此机械工作部分所占比例很少。
运营一家生产套装软件的工厂当然并不简单,但可能不比运营一家生产其他稍显复杂的消费品(例如面向大众市场的相机)的工厂更复杂。运营套装软件工厂的真正复杂性无疑来自“主版本”可用性的不确定性,主版本是指已完成的、等待复制的软件。完成智力内容(即已完成的软件)以后,事情的进展就相当顺利了。
软件生产的不确定性和复杂性严重依赖于智力活动。企业的重心要从机械工作领域转移到智力活动剧增的陌生而坎坷的世界,传统的组织结构和习惯无力应对这种转变。
复杂缜密的思想是智力产品的原材料,但大部分商业企业实际上并不鼓励思考。我们必须对企业进行一些重塑,或者用现代商业说法是“改造”它。我们必须找出人们为什么不思考的所有原因,并消除它们,不是开除人,而是清除那些原因。
本书将尝试展现成功软件企业的组织形式,这种形式无法被整齐地拆分为不同的职能单元。进度具有不确定性,产品经理必须掌握管理这种不确定性的种种要点,同样重要的是,开发人员也必须完全理解这些不确定性的重要性。而且,除非每个团队成员都有一个整体远景,否则其贡献必然会局限于仅仅执行经理或“宏程序员”为其分派的任务。这对人员潜力是一种浪费。如果想要按时交付优秀的软件,那么每个人的大脑都必须融入到项目中。让每个人的大脑融入项目并一直保持专注,这是经理的主要职责,也是贯穿本书的主题。