本页使用了标题或全文手工转换

人月神话

维基百科,自由的百科全书
跳转至: 导航搜索
人月神話:軟體專案管理之道
Mythical man-month (book cover).jpg
作者 佛瑞德·布魯克斯
原名 The Mythical Man-Month: Essays on Software Engineering
譯者 錢一一[1]
語言 繁體中文
題材 軟體工程專案管理
出版者 經濟新潮社
出版日期 1975, 1995
中文版 2004年4月4日
頁數 424頁
ISBN 9867889185
OCLC 1201368
杜威分类法 001.6/425
LC分类法 QA76.6 .B75
上一部作品 沒有銀彈

人月神话:软件项目管理之道》(英语The Mythical Man-Month: Essays on Software Engineering)是由IBM System/360系統之父佛瑞德·布魯克斯所著经典文集,全書講解軟體工程项目管理相关课题,被譽為軟體領域的聖經,內容源於作者布魯克斯在IBM公司System/360家族和OS/360中的專案管理經驗[2]。該书于1975年首次发行(ISBN 0-201-00650-2),並於1995年重新发行纪念版(ISBN 0-201-83595-9[3],其中新增了对〈没有银弹〉一文的评论和回应,與4個額外的新章節。

內容簡介[编辑]

焦油坑[编辑]

跟只為私人使用而單獨寫出來的組件程式(program)相比,做出軟體系統產品(programming systems product)所要付出的代價將是九倍以上。估計產品化(productizing)的代價是三倍,若要對組件從事設計、整合、測試,進而凝聚成為一個系統,則代價也是三倍,而且這方面的成本計算基本是獨立的。[2]

史前時期最駭人的景象,莫過於一群巨獸在焦油坑裏做垂死前的掙扎。不妨閉上眼睛想像一下,你看到了一群恐龍、長毛象、劍齒虎正在奮力掙脫焦油的束縛,但越掙扎,焦油就纏得越緊,就算他再強壯、再利害,最後,都難逃滅頂的命運。過去十年間,大型系統的軟體開發工作就像是掉進了焦油坑裏……

軟體開發的另一個難題,是從單一程式到軟體系統過程中,所造成複雜度的快速上升,期間並需要包含不同的活動技能,使得軟體開發必須面對多樣性的挑戰。布魯克斯最早認識到設計程式、開發軟體的差別,他以程式與系統產品的差異,解釋兩者之間的不同,並以3×3的複雜度加以說明。[5]

人月神話[编辑]

人月神話英语The mythical man-month):這部分講述人力(man)和時間(month)並不呈現線性關係。指出以大量人員和較短的時間,並不能縮短軟體的開發進度。一窩蜂的作業方式無助於軟體生產,且會製造麻煩,產生出更差的軟體。向進度落後的專案追加人力,只會使進度更加落後。因為新進的人員需要時間了解整個專案,而增加額外的溝通消耗。當有 N 個人必須在這群人之中進行溝通時(無階級關係),當 N 增加,其輸出 M 將抵消其效益,甚至倒退(最後幾天所完成的進度,遠不如剛開始幾天所完成的進度。像是發現了許多錯誤)。

  • 團隊交流公式: n(n - 1)/2
  • 範例:50 個開發人員,就要  50(50 - 1)/2 = 1225 個溝通管道

用「人月」來衡量工作規模的大小是危險的,也是一個容易遭到誤解的迷思,使用人月的前提必須是在人力工時可以互換的情況之下:當一份工作因具有連續性的限制而不可切分時,就算投入再多的人力,也不會對時程有所影響,生小孩就是需要九個月,你叫多少個一起生都一樣,軟體工程就是像這樣的工作,因為它必須除錯,而除錯本身就具有連續性的本質。[2]

人月[编辑]

人月英语man-month)指的是「一個要花幾個」才能完成軟體開發的單位,通常用來評估一件軟體專案的大小。[6]以成本會計(cost accounting)為基礎的時程預估技術,使我們誤把工作量和專案進度混為一談,人月是個危險並很容易就遭到誤解的迷思(myth),因為它假設人力和工時可以互換[2]

Brooks法則[编辑]

在一個時程已經落後的軟體專案中增加人手,只會讓它更加落後。[7]根據Brooks法則,增加人員到一個已經延誤的專案裡,等於是火上加油。除非你可以把工作區分,讓新進人員可在不影響他人工作的狀況下有所貢獻。

把工作切分給更多人做將造成額外的溝通(communication)代價——訓練和相互的交流(intercommunication)。欲增加軟體專案的人手,總共必須付出的代價可分為三方面:工作重新切分本身所造成的混亂與額外工作量、新進人員的訓練、新增加的相互交流。[2]

外科手術團隊[编辑]

在接受相同的訓練、同樣都是兩年資歷的情況下,優秀專業程式設計師的生產力要比差勁的程式設計師好上十倍。短小精悍團隊是最棒的——盡可能用最少的人。兩人團隊,其中一人當領導者,這通常是最佳的用人方式。以短小精悍團隊開發真正大的系統就太慢了。絕大多數大型軟體系統的經驗顯示,使用一堆人蠻幹的方式最耗成本、最慢、最沒有效率,做出來的系統在概念上也最不完整。

以一位首席程式設計師為主、類似於外科手術團隊的組織提供了一個良方,既可因少數人的決策而兼顧到產品的整體性,又可因多數人的合作與大幅溝通減少而得到全部人的生產力[2]

專制、民主與系統設計[编辑]

  • 在系統設計時,保有概念整體性(conceptual integrity)是最重要的原則。[2]
  • 功能概念複雜度比(這個比值是為了量測使用便利性,對簡單和困難的運用都很有效)才是系統設計的最終測試標準。功能多,不見得是好事。
  • 要達成概念整體性,設計必須出自於一個人的想法,或是極少數人的一致決定。
  • 對大型軟體專案(小專案也一樣)來說,將架構設計獨立於實作之外是取得概念整體性強而有利的方法。
  • 如果系統必須保有概念上的整體性,那麼就必須有人來控制這些概念,這就是需要專制的原因,無庸置疑。
  • 許多軟體架構、實作、實現的工作都是可以同時進行的。(不論硬體或軟體設計,都可以同時進行)

第二系統效應[编辑]

第二系統效應(英语The second-system effect)就一個人所做過的設計而言,第二個系統是最危險的系統,一般來說,都傾向於過度設計[2]

當他做第三或之後的系統時,之前的經驗會互相印證,以確認出這類系統的一般性特色,而系統彼此之間的不同處,也會幫助他辨別出屬於特殊和非通用的部份。除了做些功能上的修飾之外,第二系統效應還有另外一項特徵,那就是傾向於將之前已熟悉的技術發揮到淋漓盡致,但卻沒有留意到,這項技術早就跟目前專案的基本系統假設有衝突而不再適用,OS/360有好多這樣的例子。(Windows NT則似乎是1990年代的範例)

對大部份OS/360的設計人員來說,它也是個第二系統,設計成員分別來自1410-7010磁碟作業系統、Stretch作業系統、Project Mercury即時系統、給7090用的IBSYS作業系統等等,幾乎沒有人擁有兩個上述系統的發展經驗,所以OS/360可稱得上是一個最佳的第二系統效應範例。

意念的傳達[编辑]

巴別塔為什麼失敗?[编辑]

溝通[编辑]

專案工作手冊[编辑]

手冊或書面規格是不可或缺的工具,雖然光靠它是不夠的。手冊載明的是產品外部(external)規格,用來描述並制定出使用者從外觀上將或看到的所有細節,撰寫手冊便是架構設計師的主要工作。當使用者和實作人員的反應不斷地顯示出設計上難以使用或實現之處,手冊就會墮入重新準備、修改的輪迴之中。為了造福實作人員,將修改的程度予以量化(quantize)是很重要的——在時程上應該要有載明日期版本資訊。[2]

組織[编辑]

軟體需求[编辑]

失敗的軟體專案經常發生在開發者與用戶間對需求認知的誤解。開發者抱怨用戶說不清楚需求,而用戶抱怨開發者誤解他們的意思。布魯克斯認為「軟體開發最困難的單一項目,是精確地決定要建造什麼。」[8]

書目[编辑]

二十週年紀念版[编辑]

增修內容:[2]

  1. 初版中所主張的所有論斷整理出一個簡潔的摘要,包括了原書的主要理念:就人力配置的比例而言,大型軟體專案所面臨的是跟小型專案完全不同的管理問題,這引申出產品的概念整體性是其中的關鍵,而達成概念整體性雖然困難,但卻是可能辦到的。
  2. 作者佛瑞德·布魯克斯對他當初所提出的這些論斷,在經過一個世代之後所做的觀察。
  3. 轉載布魯克斯1986年發表於IEEE《Computer》的經典論文〈沒有銀彈〉。
  4. 布魯克斯對於他1986年的論斷「十年內不會有任何銀彈」所做的回應。

資料來源[编辑]

參考文獻[编辑]

腳註[编辑]

  1. ^ 錢一一,1968年生,中正理工學院電子工程碩士,目前任職於中山科學研究院,從事大型系統的軟體架構設計工作。《人月神話》是他的第一本譯作。
  2. ^ 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 Frederick P. Brooks, Jr.; 譯者:錢一一. 人月神話:軟體專案管理之道. 經濟新潮社. 2004年 [2011-04-12查閱]. ISBN 9867889185 (中文(台灣)‎). 
  3. ^ 繁體中文版係根據1995年的紀念版
  4. ^ 該書〔導讀軟體人生之何似〕本書作者Frederick Brooks對於他自己的軟體專案經歷,所做的描述
  5. ^ 鄭炳強. 軟體工程:從實務出發(Software Engineering: A Perspective from Practices). 智勝文化事業有限公司. 2008年. ISBN 978-957-729-659-7 (中文(台灣)‎). 
  6. ^ 該書〔推薦序二〕科技再怎麼變,人還是人
  7. ^ Brooks原文:「Adding manpower to a late software project makes it later.」
  8. ^ Brooks原文:「The hardest single part of building a software system is deciding precisely what to build.」
  9. ^ —. The Mythical Man-Month. Addison-Wesley. 1975. ISBN 0-201-00650-2. (英文)
  10. ^ —. Chap. 17. 'No Silver Bullet' Refired. The Mythical Man Month Anniversary Edition with four new chapters (Addison-Wesley). 1995. ISBN 0-201-83595-9. (英文)

參見[编辑]

外部來源[编辑]