鮮為人知的軟體專案管理原則

pharos發表於2019-04-01
軟體開發的殘酷的現實告訴我們:沒有規則的軟體開發過程帶來的只可能是無法預料的結果。我們中的大多數專案管理人員在其個人簡歷中紛紛寫到:"擁有多年的 豐富的專案管理經驗",但在實際開發中,"豐富的"管理經驗變成了軟體開發人員可怕的夢魘。一次次的失敗、一次次的返工,她所謂的專案管理經驗只不過是再 一次的遊戲於"無間"(十八層地獄)。一次,在與不少專案管理者的交流中,大家紛紛提到的軟體變更帶來的可怕影響。但是正如完整的法律體制不能制止犯罪, 但沒有完整的法律體制犯罪會更加猖獗一樣,頻繁的軟體變更固然可怕,但是沒有一個完整的專案管理對應機制,我們無法相像專案最終會是一個什麼樣子。此外還 有一次,筆者在求職時,招聘公司的技術主管(40-50歲左右),向我吹噓公司按CMM4的過程規則來進行軟體的開發和管理。殊不知,我一問下面開發人 員,她們在經歷無數的加班後正在給已經完成的軟體專案新增軟體概要設計書,這讓我大吃一驚。如此這樣形式主義的公司,不呆也罷。 記得一個格言曾經說過"人類最愚蠢的行為在於忘記常識"。另外一句較為相仿的格言則是"不知道歷史的人必然會重蹈覆。作為專案管理來說亦為同樣的道理。很 可惜,我們中的大多數管理者口口聲聲"軟體工程",工作時"用程式代替使用者需求",極具政客的嘴臉。其結果必然如目前媒體"程式設計師生存狀況"所言,以開發 人員在時間的犧牲為代價來換取專案的結束,這是再為普遍不過的現象,在此不再妄加評論。

如何改善我們的軟體開發管理,一條便捷之道便是"尊重常識,尊重歷史經驗教訓"。在軟體專案管理中,有許多的原則和經驗可以供我們借鑑。

一、 計劃原則

沒有計劃,你無從知道什麼時候控制和變更。制定一個詳盡的計劃,以詳細到開發人員可以理解的程度為宜。計劃能夠告訴你什麼時候應該做什麼。沒有計劃,你無 從知道自己需要做什麼。不少專案經理告訴組員需要做什麼東西后揚長而去,絲毫沒有一個相關任務(活動)之間的說明。由於沒有計劃或是計劃太粗糙、不切實 際,很多專案1/3甚至1/2的時間花在返工上面。因為計劃中遺漏了某一項關鍵任務,專案就有可能宣告失敗。試想一下,制定一個周密合理的計劃需要耗費這 麼多的時間嗎?需要付出專案失敗的代價嗎?還有很多專案管理人員常常錯誤認為"變化比計劃快",但實際的情況是,由於沒有計劃,你無法預測和估量變化給你 的專案所帶來影響,你所面臨的將會是比麵條還難以理清?混沌"狀態。此外,對於開發人員來說,"目標導向(Objective Oriented)"是充分調動其工作積極性的最佳方法,每一個任務階段的成果能夠將員工的工作效率維持在一個較高的水平。因為近期目標總是比遠期目標來 說更容易看到和達到。為此,制定一個計劃吧,讓它符合目標導向(通過各個具體任務計劃促使專案總計劃的達成)。

二、 Brooks原則

向一個已經滯後的專案新增人員,可能會使專案更加滯後。因為作為新加入的員工來說,相關培訓、環境熟悉和人員之間的溝通通路的增加,迫使專案的工作效率急 劇下跌。工作效率下降需要加班來進行彌補,但加班造成的疲勞會再次使工作效率降低。同時工作成本卻不斷的向上攀升。不過就目前來說,專案管理人員絲毫不會 理會這一點,"人多力量大"也許更能引人入勝。不少專案管理人員抱怨到時間的急迫性,須知很多專案內時間的急迫性來自於專案管理人員不假思索和不基於常理 的邀功表現,沒有充分考慮的開發人員能力的多樣性
所致。為此,正規的企業不得不耗費大量的加班費用於加班人員的津貼,同時亦要承擔違反《勞動法》的潛在法律危險。現在一種萬不得已的做法是,假設專案開發人員之間的任務的關聯性不是太大的情況下,採取兩班倒或是三班倒的方法來保證時間的延續性和相關開發人員的工作高效性。

三、 驗收標準原則

我們在進行某項任務,往往會為以何種結果為宜而感到困惑。不求質量的開發人員往往憑據經驗草草了事,追求完美的開發人員則在該項任務上耗費太多的精力,但 此番耗費未必針對該項任務,因而常常吃力不討好。這是由於沒有驗收標準而導致的情景。因為沒有驗收標準,你無法知道你要進行的任務需要一個什麼樣的結果, 需要達到什麼樣的質量標準。在很多情況下,你的活動會與期望結果背道而馳,而此時的你還在沉醉於自己的辛勤耕耘之中。作為專案經理來說,只有制定好每個任 務的驗收標準,才能夠嚴格把好每一個質量關、同時瞭解專案的進度情況。

四、 預設無效原則

你的專案成員理解和贊成專案的範圍、目標和你所制定的專案策略嗎?不少專案管理人員認為"沉默意味著同意"。實際上我們或多或少都會陷入這樣的一個思維誤 區。試想一下,你作為職員或專案開發人員時的沉默完全代表你贊成你的領導的意見嗎?不見得,這就是答案。這一點在專案溝通中極為重要,專案管理者切不可為 沉預設為是同意,沉默在很大的程度上說明專案開發人員還尚未弄清楚專案的範圍、任務和目標。為此專案管理者還需要同開發人員進行充分溝通,瞭解開發人員的 想法。在對專案沒有一個共同的一致的理解的前提下,一個團隊是不可能成功的。

五、 80-20原則

80-20原則在軟體開發和專案管理方面有許多"例項"。其一便是我們在20%的專案要求上耗費了80%的時間。仔細分析一下,這些專案要求分為必須的非 必須的,因此我們建議是壓縮非必須的部分或是暫時將其放在一邊不必太重視。軟體專案開發事實告訴我們,開發人員在非必須的專案要求上耗費了太多的精力,用 戶的需求變更的大部分出現在"最好有"這一部分,實際上使用者並不看重這些需求(即使去除這些需求),而我們所做的,往往是捨本求末。

80-20原則的另外一個例項是我們專案中的20%的人員擔當了80%的專案任務(這樣講在實際實施中一點都不過分)。考慮到開發人員能力的多樣性,聰明 的專案管理人員決不會採取任務均分的愚蠢做法,因為就係統論的觀點來看,互補結構比對等結構要更穩定一些。此外作為專案管理人員來說,瞭解屬下員工的能力 特點,將其放在合適的位置上,會更有利於專案的順利進行。很多管理人員常常抱怨屬下能力問題,究其實質,往往是這些專案管理人員未能發現開發人員潛能所在 之處。她們看待問題往往以"經驗"這樣的思維定勢來做決定。導致的結果如系統論所言:由於"抱怨"的作用和反作用迴圈,結果是大家都不歡而散。

六、 帕金森原則

帕金森原則原是用於反映政府部門機構臃腫,效率低下的代名詞。不過它在軟體開發中一樣適用。沒有時限限制的話,工作可能無限延期。在軟體開發中,如果沒有 嚴格的時間限制,開發人員往往比較懈怠。這是人的天性所決定的。千萬不要指望奇蹟的發生――"所有員工的思想覺悟異常崇高"。作為專案管理者而言,此時應 充分考慮到員工的工作效率和專案變更帶來的負面影響,制定合理的專案工期並鼓動開發人員儘快完成。

七、時間分配原則

在專案計劃編制過程中,我們常常將資源可用率(人、裝置)等設定為100%,殊不知你曾想過,由於開發人員需要休息、吃飯、開會等,根本不可能把所有的時 間放在專案開發工作上,而且這還不考慮到開發人員的工作效率是否保持在一恆定水平上。所謂一天8小時工時制實際上是徒有虛名。由於專案管理人員的"無知 ",不少開發人員被迫拼命加班。結果依舊出現Brooks原則所出現問題。在實際開發中,開發員工的時間利用率能夠達到80%就已經時很不錯的了,我個人 比較傾向於60%左右(黃金分割點)。一個常用的經驗是如果專案人員不懂技術的話,專案時間可能是原計劃(該計劃沒有考慮到資源可用率)的4/3- 5/3。如果專案人員不懂技術、管理人員不懂管理的話,這個數字可能是2倍到3倍。現實就是這麼嚴酷。這很大範圍內"歸功於專案管理人員。是的,我們的確 沒有必要責備開發人員,因為我們對資源可用率的判斷完全違反常識。

八、變化原則

也許有人問過你,在專案管理中唯一不變的東西是什麼?我可以告訴你,專案中唯一不變的就是"變化"。在專案中不考慮可能發生的變化是不可思議的。不過在面 對專案可能發生變化而帶來的專案風險時,我們的專案管理人員往往會懷有逃避的態度。經濟學裡大名鼎鼎的風險規避原則便是專案管理人員心理的有效描述。作為 專案管理人員來說,應該及早預測可能出現的風險,做好風險儲備。雖然風險儲備不能解決所有的問題,但預防勝於治療"。可惜的是我們絕大多數人沒有這方面的 意識,否則醫院的生意未必如此紅火,專案開發之途未必如此坎坷。

九、作業標準原則

一個團隊要完成專案的開發需要有一定的章法。很可惜,在國內目前仍然以"作坊式"為主,高舉"我們符合國際CMM X規範(ISO某某規範)"的環境下,未必有多少專案團隊注意到這一點。我們曾經驚歎印度的高中生都能程式設計序,而國內卻非本科、碩士不收眼簾。究其原因, 在於沒有開發章法或是章法粗糙,猶如牛皮聖旨一般。一個好的程式碼模板和程式碼規範能夠解決大多數人編寫程式隨心所欲的問題,很可惜,沒有多少專案管理人員有 此意識,也沒有多少人願意去做這項基礎任務。業務軟體開發需要高超的開發技巧嗎?不需要,那是故弄玄虛的開發人員的伎倆。軟體開發的美在於其簡潔性和規範 性,不在於奇技淫巧。因為缺乏作業標準,我們付出的代價是客戶的抱怨和無休止的返工。此外,對於那些以形式主意蒙人的專案團隊來說,如果你實質如同你口頭 所說那樣,也許你就不會是今天的這副狼狽相。

十、複用和組織變革原則-解決專案問題的未來之路

如何解決日益突出的專案工期、成本、質量等問題,這是大多數專案管理者最為關心的問題。從實踐來看加強複用的力度,建立專案複用體系和實施組織變革是效果 較好的途徑之一。複用能夠提高專案的生產率,降低專案風險。通過複用,專案管理者能夠快速的進入專案問題定義之中,減少專案開發人員的工作量,從而儘可能 的解決專案在時間、資源方面的過載問題。另外一條途徑是實施專案團隊的組織變革(Moc),精簡專案管理機構、重新定義工作職責,制定柔性的專案工作流 程,改善專案開發人員的溝通狀況,提高專案人員的開發效率,努力營造一個良好的專案開發環境。這樣才能從根本上解決專案開發的種種棘手問題。

結論

作為一個專案管理者來說,瞭解和運用上述原則是不夠的,若要深入的掌握專案管理知識和技巧,還必須深入學習專案管理(建議參看PMI《PMBOK》)、管 理心理學、質量管理學、組織變革、系統論等方面的知識,並在工作中不斷的總結和實踐。唯有如此,我們的專案管理人員看自己個人簡歷時方不會覺得臉紅,才能 在公司中樹立自己的管理權威性,同樣也才會有一個良好的職業經理生涯的開端。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3433/viewspace-142361/,如需轉載,請註明出處,否則將追究法律責任。

相關文章