现代软件工程讲义 5 项目经理 Program Manager

在一个软件团队里, 不同的人有不同的投入, 我们在 猪,鸡和鹦鹉 的故事里已经说明了. 不同的人还要在团队中担负不同的任务, 我们也要讲一下.

开发人员 (大部分内容在:   现代软件工程讲义 2 工程师的能力评估和发展

项目经理   ( 这篇博客 )

测试人员  ( link )

 

 

0. PM

我碰到的不少大学同学都有一个想法 - 先做几年技术, 然后做管理; 也有一些同学说 - 我技术不行, 希望直接找到一个管理的工作, 就像PM 那样。

PM 的M 就是 manager, 但是 P有这几种: Product Manager, Project Manager, Program Manager, 在不同的行业和公司它们的作用不一样。 下面说说微软的PM - Program Manager:

1. 微软PM 的来历

大部分公司的项目经理叫 Project Manager, 微软的经理叫 Program Manager, 这有什么本质的区别么?

微软曾经也是一个创业公司, 两个创始人都是 dev, 招聘的新成员也大多是像他们一样的开发人员, 这其中就有一个叫 Charles Simonyi 的超级程序员 (当然还有像 Steve Ballmer 那样的超级销售人员, 这里按下不表)。

 

image

 

1974 年, Charles Simonyi 在Xerox PARC 开发了 WYSIWYG (所见即所得) 的字处理软件 Bravo, 成为 PARC 的 Alto 个人电脑的重要应用软件。 

作为参照:

    同一年, Steve Jobs 从印度回来, 加入Atari 公司打工, 因为其他员工不能忍受他的傲慢态度和卫生习惯, 他只好上夜班。

    同一年, Bill Gates 在哈佛大学读 2 年级, 第二年, 他看到了个人电脑的曙光 – MITS Altair 8800, 于是退学创立了 Microsoft.

 

1981 年, Charles 加入了微软公司, 领导 Word 和其他办公软件的开发。   很多开发人员聚集在一起, 怎么工作呢?  如果大伙做的是搬砖的体力劳动 (我很喜欢用搬砖的例子),  那么在一定限度内, 人员的增长和项目复杂度的增长是线性的关系; 程序开发就有些不同, Charles 发现项目管理的复杂度似乎是和人员数量的平方成正比。  一个团队里有 4 个成员, 就有 6 种双向依赖和交流的途径, 然后增加一位新成员, 就要增加 4条新的双向依赖交流的途径。 对于 N 个成员的团队来说交流的途径总数是 n * (n-1) /2, 这种 N 平方的增长意味着这样的交流对人类来说是不可持续的。

 

image

 

怎么办?  Charles 想到了一个办法 - 他提议把程序员分成 Master Programmer (MP) Slave Programmer (SP), MP 和其他成员交流, 了解需求, MP 只写抽象的伪代码, 或者对功能的描述; SP 根据MP 的文档, 实现具体的功能。 SP 只用和 MP 交流。  这样不就大大减少了交流的成本么?

这个想法在理论上是好的, 但是在实际上, 没有人想做 Slave Programmer, 刚加入团队的成员问 - 为什么我们不能当 Master Programmer?  这次改革最后不了了之。

 

但是, 随着软件复杂度的提高, 用户需求的多样化, 市场竞争的日益激烈, 光有程序员和销售人员是不够的。 我们需要专门人才来做下面的事:

怎么让软件变得可用 (usable), 有用 (useful)

销售人员把顾客的需求直接告诉开发人员, 但是开发人员往往听不懂。 我们需要专人来把市场/销售人员那一套 MBA 的套路翻译成程序员能懂的功能说明 (spec) 

一个产品团队要做很多事, 这些事往往是程序员不愿意花时间的:

  1. 和客户交谈, 组织用户调查, 发现用户需求
  2. 了解和比较竞争对手的产品
  3. 怎么改进团队的流程

谁都不愿意做, 谁都没有能力做好, 大家宁愿盯着屏幕写代码。  怎么办呢?  这时候有另一个聪明人出现了, 一个叫 Jabe Blumenthal 的程序员提出了 Program Manager (PM) 的头衔, 并成为了微软第一个 PM (1984年, Excel 团队)。 和不少早期微软公司员工类似, Jabe 从微软退休, 当中学老师, 做公益活动去了。 (链接)

PM 做什么呢? 

2. PM做开发和测试之外的所有事情

有些同学说,我写的代码都不用测试, 我真想不到除了开发和测试之外,还有什么事情可做。  我们看看 微软公司有哪几类的PM:

  • 有做功能设计的PM; 有些需要很深的计算机科学各个分支的专业知识 (如 Visual Studio 各种语言,框架, TFS 的项目管理, SQL Server, Windows Server, Windows Azure, Bing Search 等团队的PM ); 
  • 有些需要对商业和客户很强的了解能力 (如 Office 应用软件的PM );
  • 有些需要广泛的经验和知识面, 商业拓展能力 (如 MSN 部门的 PM); 
  • 有些是驱动流程的PM, 例如推动几百人的团队完成一个版本的开发, 又如保证 Windows Phone 在几十个不同硬件上能发布;
  • 也有专门深入某一领域的 PM (如国际化/本地化 localization/globalization); 
  • 还有和研究人员合作, 琢磨前沿技术如何能进入主流产品,做技术转化的 PM。

 

Program Manager 和一些公司的 Project Manager 的区别:

 

Project ManagerProgram Manager

是团队的行政领导, 带领大家在项目中工作。

和大家平等工作, 推动团队完成软件的功能。

通常是团队和外界打交道的唯一代表一个团队可以有很多PM
对项目的功能有最后的决定权和其他团队成员一起形成决议
管事也管人管事不管人
不一定做具体工作一定做具体工作

 

在别的团队中, 也有产品经理的职位, 例如这个博客 (和书) http://iamsujie.com

问: 既然PM 这么厉害, 为什么不让他们领导开发人员和测试人员, 这样 PM 工作起来不就是更有利了么?

答: 首先, 我们认为好的产品设计是在平等讨论 (甚至争论) 的基础上产生和完善的, 如果讨论的一方同时又是另一方的老板, 则无法进行平等和无拘束的讨论。

其次, PM 的产品是 spec (规格说明书), PM 要凭自己的能力, 把用户的需求展现成 dev/test 能够了解, 能够执行的语言, 从而赢得同伴的信任和尊敬。 如果PM 同时又是其他人的老板, 则不必写太好的 spec, 用命令即可说服别人。 再次, PM 不一定是很好的行政经理, 硬把管理不同专业的 dev/test 的任务加到PM 头上, 反而会坏事。 关于这个问题, 这里也有一篇讨论.

 

问: PM 最大的, 最独特的贡献是什么?

答: 保持团队的平衡。

 

image

一个软件产品几乎做不到同时又多又快又省。 在别的领域也类似,  中国在大跃进期间提出了 多快好省 的要求。 最后只得到一个 “多” -  人多。 (参见 软件工程的估计)

 

大部分优秀的团队可以做到两个:

多, 快, 但是不省

多, 省, 但是不快

快, 省, 但是不多

PM 要带领团队选择哪两个是最重要的, 哪一个是可以牺牲的。

 

还有许多不那么优秀的团队也许勉强可以做到一个:

多, 但是不快, 不省

省, 但是不多, 不快

快, 但是不省, 不多

 

当然还有一些团队一个目标也达不到, 中途作鸟兽散了。

 

问: 我们团队有几个程序牛人, 参加过 ACM 比赛什么的, 他们写的程序都不用测试, 为什么还要 PM? 如果PM 也来开发, 是不是项目进展更快?

答: 程序 和 软件有区别,  请看:  http://www.cnblogs.com/xinz/archive/2011/05/22/2053838.html

     其次,在下面的图中, 团队有很多划船的牛人, 还有一个拿着话筒的舵手. 如果这个舵手也开始划船, 后果会怎么样?

 

image

 

可能小船的速率会快一些, 但是小船的方向, 稳定性会出问题。 船快了一些, 但是划桨的队友很累, 船不稳, 而且最后到了一个计划外的地方,你愿意么? 

 

在软件行业发展的最初, 软件都是为维持机器本身的运作服务, 或是做科学计算, 这时候也许看不出 PM 的作用。随着产业的发展, 软件应用的深度和广度, 软件的复杂度, 软件团队的复杂度极大地提高了, 这时候我们需要一些人来起着沟通, 交换, 影响, 润滑, 讨价还价的作用 - 就像商业社会的金钱一样 – PM 就是这样的角色。 

 

问: PM 文化的盛行有副作用么?

答: 任何方法或文化都有优点和缺点,  PM 太多了以后,  由于大部分决定都是经过平等而反复的讨论协商折中的到的, 一个后果是 “design by committee”, 一些产品不能很快跟上市场变化, 在需要个人特色的方面, 如设计/UI, “committee”设计出来的东西大多中规中矩, 但是很多方面了无新意。

牛人主导的项目,往往有大起大落,在PM主导的产品中,“不犯大错”成了一个特点,微软的很多产品在长期的竞争中, 靠“不犯大错”,从第三版开始,赶上并超越对手。这也是一个了不起的能力。 [注8]

 

Scott Berkun 也谈到了一些副作用:  http://www.scottberkun.com/blog/2009/the-lost-cult-of-microsoft-program-managers/ 

3. PM 的能力要求和任务

成为一个团队的PM, 需要哪些能力呢?

学习能力: 在一个新领域中能很快上手

观察理解能力: 能理解用户, 站在用户的角度上考虑问题, 观察发现用户不善于表达的需求, 观察团队成员的言外之意, 老板/客户/利益相关人的弦外之音.

                      什么是同理心? 就是能够理解别人的处境, 心理, 动机的能力。 西谚有 – put yourself in other people's shoes, 正是此意。

分析管理能力: 每天项目中发生的事情千头万绪, 能够分析出重点, 找到优先级, 做决定…

一个项目和个人一样, 每天都会碰到各种问题:

    重要而紧急的         - 网站崩了!  

                                - 程序员二柱突然说他要离职! 

    重要而不紧急的      - 按照流量和内容的发展趋势,  三个月后, 目前的架构似乎撑不住, 但是现在还凑合… 

                                 - 程序员们都不写文档, 他们三个月前说等忙过之后会写的, 但是…

    不重要而紧急的      - 老板的老板问到了项目的进度!  要写一个PPT,请若干人征求意见

    不重要且不紧急的   - …

PM 如何处理这些事情呢?

 

销售能力:  能满怀激情地向用户兜售产品, 向团队兜售希望。 请看 Steve Ballmer 的销售能力展示.

交流能力, 处理冲突的能力: 其他角色碰到冲突一般会来找 PM. PM 也要鼓励团队成员保持斗志。

一定的专业能力: 写代码, 玩转Excel, PPT, Visio, 甘特图, 会PS, 有文字功力, 能写有人读的博客, 总得有几招绝活吧!

转换角色的能力:   一个PM 能玩转很多高技术的工具, 但是当工作需要, 她能突然把自己变成一个完全不懂技术的菜鸟用户,从用户的角度来看问题 …

自省的能力: 一个PM 做第一个项目的时候可以拍脑袋定工期, 拍胸脯打包票, 最后拍屁股走人  (谁没年轻过呢?)。 但是失败之后要有自省和自我改进的能力 (看这个例子)。

 

在生活中能不能锻炼PM 的能力呢?

  可以, 装修房子, 组织一个大型活动, 等等。 

在一个项目中, PM 的具体任务是什么呢?

带领团队形成团队的目标/远景, 把抽象的目标转化为可执行的, 具体的, 优美的设计。

管理软件的具体功能的生命周期 (需求/设想/设计/实现/测试/修改/发布/升级/迁移/淘汰)。

创建并维护软件的功能说明书 (specification), 让它成为开发/测试的及时准确的指导, 而不是障碍。

代表客户和用户的利益, 主动收集用户反馈, 预期用户新的需求。 协调并决定各种需求的优先级。

分析带领其他成员形成对缺陷/变更需求的一致意见, 并确保实施。

带领其他成员确保项目保持 功能/时间/资源 的合理平衡, 跟踪项目进展,  确保团队发布让客户满意的软件。

收集团队项目管理和软件工程的各种数据, 客观地分析项目实施过程中的优缺点, 推动项目成员持续改进, 从而提振士气。

 

成功的PM 如果得到团队成员的支持, 会是什么样?

成为项目流程的主人 - 驱动流程, 会议, Scrum, 进度

代表团队, 向上级/伙伴团队/客户/市场部门 报告项目进展

团队成员都乐意和你交流,  你赢得大家的尊重

你不用自己写一行代码,也同样可以积极地影响项目和产品

 

PM 如果得不到到团队成员的支持, 会是什么样?

在各种会议或流程中浪费大家的时间,  发一些大家不读的 “Status Mail”.

不能凝聚团队, 形成共识

对团队的状态不了解, 也不能有效和准确地向有关方面报告团队的情况, 获得支持,但偏偏还不断打扰团队成员,纠缠一些过时的问题。

对项目和产品造成负面的影响。

PM 还会和团队成员因为对投入的认识不同而产生误解, 参考 猪,鸡和鹦鹉,当队友期望你是“猪”的时候 , 你偏偏当个“鸡”;当队友期望你作为“鸡”而搞定某一事情 , 你却偏偏当个飞来飞去的”鹦鹉”!

 

4. PM 们的故事

讲了这么多条条框框, 我们还是讲几个故事吧:

 

A) 是不是所有的好功能都是由PM 主导, 一步一步根据用户需求,按照用户场景设计,然后可用性测试等等步骤之后得来的?

功能本天成,妙手偶得之——一个来自微软的故事。[注3]

约摸在1985年,微软的一个叫Steve Hazelrig的工程师正在写Mac Excel 版本的打印功能,那时候激光打印机很贵,而且离办公室也不近。他懒得经常跑到打印机那儿取打印纸,检查打印效果,就写了一个小程序,把要输出到打印机的图像显示在屏幕上,还有一个放大镜功能可以把局部放大以检查每个像素的位置及效果。这时一个PM路过看到了这个小工具,说,这么酷的东西,为啥不做成一个功能呢?

所以后来微软的编辑软件都有“打印预览”这一功能。然而,用户们并没有正式地要求这一功能。

B) PM 怎么说服聪明的同事
这个故事在 [注4, 注5] 中都提到了. 在Macintosh 研发的过程中, 由于计算能力的限制, 计算机的图形显示非常缓慢.  一位聪明的程序员展示了他的新算法, 能很快地画圆形和椭圆. 当他得意地展示给 Steve Jobs 看的时候,  (作为一个不懂编程技术的 PM,Steve 应该表示仰慕才对…) Steve 看了之后, 反问 - 你能继续改进, 让圆角的矩形框显示速度加快么?   程序员说: 这个太难了, 也没有必要.  椭圆不是挺好的么?  Stevel 为了说服同事, 建议两人到外面散步, 然后指出现实世界中的各种告示牌都是用 圆角的矩形框 来实现,走了一圈, 同事就被说服了。 过了几天, 圆角的矩形框也可以很快速地在屏幕上显示了。
C) PM 如何找到需求
一些人常说PM 负责提需求,  Dev 就管实现就好了,  那需求从哪里来呢?  <Social Network> 这部电影提到这样一个情节: Mark在忙着写早期的 "the facebook" 网站, 一个同学来打听他认得的某女生有没有男朋友,  Mark 听了, 赶紧把 "显示交友状态" 这一功能加到了网站上。 你说他是不是一个好的PM? 
 
D) PM 的分析能力和韧性
能把市场, 我方的优势和劣势, 创新的机会讲得头头是道, 也是一种能力。 在软件工程课上我们讲过 NABC 方法。  乔布斯在 NeXT 公司时那样也做过很有说服力的分析:
http://v.youku.com/v_show/id_XMzE1Mzc2NTE2.html 
注意, 这么厉害的 PM, 分析的这么透彻, 但是 NeXT 的产品还是失败了. 
但是乔布斯没有气馁, 又投入了另一个公司的运作 – Pixar.  
你有这些能力么?

微软的PM 有独特的历史和价值, 正如 Steven Sinofsky 讲的: 一直被拷贝, 但很少成功复制… [注6]  [注8]。新的技术浪潮和商业模式给 IT 人士提供了一波又一波的机会,了解PM 的特点和要求,对要想进入这一领域的同学来说很有好处。

 



 

 

[注1: PM来源: http://www.joelonsoftware.com/items/2009/03/09.html]

[注2: PM 在微软的工作: http://blogs.msdn.com/b/jmeier/archive/2010/07/03/what-is-a-pm-at-microsoft.aspx ]

[注 3:  源自微软的[口述历史] ]

[注4:  Revolution in the Valley]

[注5: Steve Jobs, by Walter Isaacson]

[注6: Steven Sinofsky 关于PM @ Microsoft 的博客:  http://blogs.msdn.com/b/techtalk/archive/2005/12/16/504872.aspx ]

[注7: Scott Berkun 也曾是微软的PM, 他写了一本很好的PM 手册: Make Things Happen ]

[注8: Eric Brechner 最近也对微软的PM 发表了意见: http://blogs.msdn.com/b/eric_brechner/archive/2012/07/01/pm-secret-weapon-or-wasted-headcount.aspx ]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/500434.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

现代软件工程讲义 5.1 软件的质量保证 (QA) 和测试 (Test)

在一个软件团队里, 不同的人有不同程度的投入, 我们在 猪,鸡和鹦鹉 的故事里已经说明了. 不同的人还要在团队中担负不同的任务: 开发人员 &#xff08;大部分内容在: 现代软件工程讲义 2 工程师的能力评估和发展&#xff09; 项目经理 ( 内容在这里) 测试人员 ( 本篇博客 ) 团…

现代软件工程讲义 8 稳定阶段 (测试的计划和执行)

[来自 移山之道 第 13 章] 13.8 测试计划 测试不是在所有的开发工作完成之后才进行&#xff0c;而是与开发几乎同步进行的。一个软件项目的各个功能都可以有自己的测试计划&#xff0c;它们可以在不同的阶段发挥作用。但是针对整个项目的总测试计划&#xff08;又叫测试总纲&a…

现代软件工程讲义 2 开发技术 - 效能分析

[移山之道 第九章] 9.4 VSTS 效能分析工具 啊&#xff0c;效能分析&#xff0c;Performance&#xff01;这是每一个程序员都梦想的事儿&#xff0c;让自己的程序跑得又快又好&#xff0c;最好是比别的同学快一个数量级&#xff0c;别人的程序是O(N^2)&#xff0c;而我的程序是…

现代软件工程讲义 2 开发技术 - 单元测试 amp; 回归测试

[移山之道 第11章] 1单元测试 你的RP是由你的程序质量决定的。 ——阿超 这一章讲的是两人合作&#xff0c;既然程序是两个人写的&#xff0c;那就会出现一个人写的模块被另一个人写的模块调用的情况。很多误解、疏忽都发生在两个模块之间。如何能让自己写的模块尽量无懈可击…

现代软件工程讲义 4 方法论 - MSF

[内容来自 移山之道]白话MSF方法论 2.1 果冻的预习果冻&#xff1a;超总&#xff0c;听说你要讲MSF&#xff0c;我就先预习了一下&#xff0c;但是MSF的名词太多了&#xff0c;我真是头大&#xff0c;能不能解释一下这两句&#xff1a; “MSF的一个基础原理是学习所有的经验。…

现代软件工程讲义 9 测试 关于闰年的测试

我们谈了不少测试的名词, 规范和原则 (link1, link2). 软件是人写的, 测试计划和测试用例也是人写的, 人总会犯错误。错误发生之后, 总有人问: 为什么这个bug 没有测出来啊?! 我们看看一类简单的bug是如何发生的&#xff0c;以及如何预防它们再度发生: 闰年 软件少不了和…

现代软件工程 来自卓越大学教师的建议 (读书笔记)

教师教学有培训和参考书么? 我从来没想到过我会在大学里教书, 而且还教了好几年, 四个学校。 当时接到任务的时候, 我把它当作实习生培训和新员工培训的”学院版”, 还是继续强调实践, 反馈, 合作, 就这么开讲了。 在微软公司, 做大部分和人相关的事情, 都得先有一个培训, …

软件工程讲义 9 创新的出路 走进作坊

我第一次注意到 “作坊”这个词和软件行业联系起来大概是这个 2004 年 11 月的报道: 标题: 信产部副部长娄勤俭&#xff1a;中国软件业还在手工作坊阶段 日前&#xff0c;信息产业部副部长娄勤俭在出席中国软件产业生态链高层论坛时表示&#xff0c;中国软件产业的规模还比较小…

现代软件工程 习而学的软件工程教育

茅于轼先生写了一篇博客 ( http://blog.sina.com.cn/s/blog_49a3971d0102dufj.html ) 纪念茅以升先生提出的 习而学的工程教育: 把颠倒了的工程教育顺序恢复过来&#xff0c;即他称之谓“习而学的工程教育”。 以桥梁建筑专业为例&#xff0c;大学一年级先学施工条例&#xff0…

现代软件工程 教课心得

现实世界是最好的老师, 我们这些叫 “老师” 的人, 充其量是个助教。 但是有些助教却不让学生见到老师。 **************** 老师都想把课教好, 学生都想把课学好. 但是我们常常看到一个学期过后, 老师, 学生都有很多抱怨 (例如: 各种良好愿望和计划在实施中的问题). 看了上…

微软学术搜索项目 10个版本的历程

这是我在微软亚洲研究院参与的项目之一, 从 2009 年秋天开始, 我们小组把它从一个研究原型发展为涵盖全学科的学术搜索门户。 它索引了 4千万论文, 2千万作者, 6 大实体类型, 8 种数据可视化功能, 具有开放的API 平台和手机客户端. 下面说说项目的发展: 2009/8: 内部发布 alp…

现代软件工程讲义 9 测试 QA 的角色和分工

测试的角色 (Test) 要独立出来么 ? 独立出来的测试角色怎么才能发挥作用? 有些成功人士和成功的公司号称没必要有独立的测试角色 (Test), 你怎么看? 最近又看到一些关于开发人员要不要负责测试的讨论。 例如: http://www.aqee.net/on-testers-and-testing/ 大多数的开发…

程序设计作业: 车模+数模 = ?

我上学的时候只听说过 “航模”, 没听说过“数学建模”这门学问. 这几年在简历里看到过不少人号称数模得过什么奖之类的, 我都没好意思问太仔细。 在帝都开车经常遇到堵车, 我于是想到了一个车模的问题。 我想请大家帮着给这个车模搞个数模, 求个解法: 想象帝都北四环或北五…

计算机考研的调查和改进建议

几星期前, 我在微博上讨论考研的事, 有专家建议不如把意见整理出来, 说不定可以转告给相关方面。 我没有考过研, 问了公司的同事们, 绝大多数都是保研的, 也没考过。 我从网上下了一份模拟题, 好像还挺难&#xff0c;有一种要翻书的冲动。 全国有多少学生为了考研而奋斗? …

2012 夏季高校微软俱乐部活动 - 开门创新

创新啊创新, 大家都在讲创新。 一般的理解, 创新就是公司内部关起门来想, 实验, 内部评审, 然后申请专利什么的, 其实也有开门创新的办法: http://www.innovationexcellence.com/blog/2012/08/13/40-examples-of-open-innovation-crowdsourcing/ it is about bringing extern…

笔记 - 高等教育的创新

教育是一个社会发展的支柱, 你和我能看到并理解这个博客, 教育功不可没。 高等教育的形式并不是一成不变的, 高等教育一直在演进, 变革中, 最近一股“online higher education” 的浪潮在美国兴起, 貌似突兀, 其实有规律可循。 在关注最近的在线教育浪潮之前, 我们看看美国高等…

现代软件工程讲义4 Scrum/Sprint

Advanced Software Engineering, Development Process, Scrum/Sprint 软件开发的流程有很多 (看 各种方法论概述), 我也写过一篇博客 (酒后的敏捷) 谈了谈最近比较时髦的开发流程。 今天我们不喝酒, 正襟危坐地说说敏捷这一路 Scrum/Sprint 开发方法. 从理论上看, 这个方法真…

现代软件工程讲义 7 设计阶段 Spec

在前一个博客里 (典型用户), 我们讲了怎么收集, 分析和验证用户的需求。 这里我们讲 spec – specification Specification, 又叫spec, 有两种: a) functional spec, 软件功能说明书, 主要用来说明软件的外部功能, 和用户的交互情况 (把软件当作一个黑盒子) b) technical spec…

现代软件工程 2012 北航 项目复审模板

这是现代软件工程课在北航的项目复审要求。 这次我们有下列 10 个团队, 他们做了一些有意思的项目&#xff1a; 有七个小组合作&#xff0c;携手打造一个叫 学霸 的网站: 100Years 网页收集和归类工具76er 网页收集和归类工具FightingSnail 网页元数据抽…

现代软件工程讲义 8 软件的血型

[这是 现代软件工程讲义 的一篇] 一个软件团队经历了计划/设计/开发等阶段, 达成代码完成 (Code Complete) 这一目标&#xff0c;似乎后面的事情就水到渠成了. 其实不然, 软件生命周期的最后阶段往往是最考验团队的&#xff0c;不但考验团队项目管理水平&#xff0c;应变能力…