現代軟體工程講義 0 課程概述
大家可以從各種各樣的健身館中看到這樣的關係, 像健身,減肥,瑜珈等等。 在這種關係中, 是誰想提高自己水平? 是那些學員, 這些學員的想法得足夠強烈, 他/她才會花錢去參加這樣的健身活動。 在健身活動中, 誰要做各種運動, 流汗呢? 是學員。 誰在這個活動中對別人指指點點, 鼓勵別人更加努力? 是教練。那為什麼教練可以這樣做? 因為教練有下面的資源:教練的資質, 教練本身應該在所教的項目中是很有經驗的身體力行者。 如果我光看了很多瑜珈的書籍和錄像, 或者得到某老師的PPT (如果瑜珈老師用PPT 的話), 我然後就照本宣科去教瑜珈, 雖然我講的話和一個資深瑜珈教練的話沒什麼區別 – 「現在開始練習冥想, 要盡量讓自己內心安靜下來,要保持呼吸均勻, 把精神集中在體內 …」 可以肯定留在我這個班裡的學生不會很多。教練有一套訓練計劃和各種練習方法, 教練(場館) 有儀器, 工具, 設備, 不是每一個人都打算在家裡放一套各種重量的啞鈴和杠鈴。教練可以隨時指出學員鍛煉的進步和不足。教練(場館) 能召集到有一群相似基礎的隊友, 這在有些類型的鍛煉是很重要的。教練和學員的關係如果確定, 就很好辦了。 每一個來學習的學生, 都是想學好軟體工程這門技術才來的。 各人的先天條件不同, 目標也未必相同。 有些同學想成為世界一流的程序員, 那老師就會以世界一流的標準來要求學生。誰要在這門課中寫代碼, 做實驗, 找需求, 修bug?是學生, 不是老師。誰要看各種與軟體工程相關的書籍, 博客, 並定期彙報?是學生。誰給各個學生設計練習, 回答疑問?老師。如果學生的努力低於他自己目標的要求, 誰會批評這個學生?老師會。有些學生說 - 老師, 你講的特別好, 我特別想提高, 但是我太忙了, 所以沒時間寫程序, 我就是來聽聽。。。這種情況放在健身學員的類比中會是這樣:教練, 你講的特別好, 我特別想減肥健美, 但我太忙了, 沒時間練, 所以我辦了卡, 就是來聽聽。。。[這種學員還真的有, 據說健身場館的很大一部分利潤是來自於那些辦了年卡但是很少來的人]教學方法那麼軟體工程課一般是怎麼教的呢? 我在這一篇文章里也提到:軟體學院的小慧老師對阿超抱怨,軟體工程這門課看似容易,實際太難教。小慧說:我是按照經典的瀑布模型來講課的,本來以為會是高屋建瓴,一瀉千里,但是實際情況是這樣的:需求分析:學生們都不懂企業的需求是什麼,上課睡覺。設計階段:學生們畫了許多 UML 圖,用設計工具畫了不少矩形框,菱形框,如此而已實現階段:學生們開始討論非常細節的問題,UML 圖早已經扔到一邊。穩定階段:學生們中十分之一的人開始寫代碼,其他人不知道在幹什麼.代碼大部分情況下都不能工作,所有設計好的種種黑箱和白箱測試都無從開始。發布階段:這個只有一天時間,就是最後檢查的那一天,同時還有人在調試程序.維護階段:課程結束了,同學們對自己的產品沒有任何維護,放假了!最後大部分同學們都說這門課特別沒用,自己根本沒學到什麼本事,然後下個學期,新的一批學生進來重複這一過程。。。我在文章中建議, 軟體工程的教學應該考慮讓學生一直能保持有具體的事情做, 而且做了之後能看到效果。 不要在學生剛上課的時候就要求寫一個需求分析, 學生上哪裡分析去? 如何看到效果?所以在《現代軟體工程》 這門課中, 我安排了個人項目, 兩個結對項目, 讓大家充分有時間把個人技術和一對一的合作技術做好, 然後再開始團隊項目。 一個理想的流程應該是這樣:開始維護以前同學開發出來的程序,理解程序。找bug,改bug,重構小部分代碼,以滿足用戶的需求。一部分同學可以開發測試用例在現有版本的基礎上做增量開發 理解需求 (這個時候理解了客戶需求是什麼)設計開發回歸測試 (用到上面開發的測試用例)負擔問題很多學生一聽說我給他們安排的學習計劃, 第一個反應往往是 - 負擔太重了! 讓我們回到健身館, 如果一個體質正常的青年想健美, 教練安排他舉杠鈴, 他會說什麼呢 – 「杠鈴太重, 我走了!」負擔是相對的, 這要看大家要跟誰比了。 我在清華大學上課的時候, 也有學生反映「負擔太重」, 我只好和他們一起回憶清華大學校長及各級領導提出來的目標 – 「建設世界一流大學" . 如果要建設世界一流大學, 那要跟世界一流大學比。 在軟體和軟體工程方面世界一流的大學是哪一家呢? 我想唯有跟卡內基·梅隆大學 (CMU) 相比, 才能不辱沒清華大學的名聲。CMU 有一門本科生的課 -Build Virtual World, 是由已故的Randy Pausch 教授講授的, 我們可以比較一下。CMU – Build Virtual World現代軟體工程5 projects/semester2 week/project, done by 4 person teamRotate team member in each project4 project/semester:1 Idividual Proj.2 Pair Proj.1 Team Proj.team project has 6 people.rotate team member in each project.他們一個學期要做 5 個項目, 我們只做 4 個。誰的負擔重?所以, 不是我要為難大家, 而是校領導的意思, 同學們可以找校領導說 – 我們不想成為世界一流大學, 成為五道口一帶的二流大學就可以了。 如果領導同意了, 我當然可以降低負擔, 而且我還可以把師生關係調整為 「哥們/哥們」, 要混還不容易嗎?!我們可以看看古代的歷史, 為古羅馬帝國開拓疆土的士兵, 他們是如何培訓的呢? 請選擇:a) 他們不經過培訓, 直接上戰場b) 他們只學理論, 沒有實戰c) 他們用比實戰更輕的武器訓練d) 他們用和實戰一樣重的武器訓練e) 他們用比實戰重一倍的武器訓練先別說成為世界級的士兵或將軍, 如果大家想在戰場上活得比別人長, 你會選哪一項呢?
這個道理對IT 行業的學生也是一樣的, 在人潮洶湧的招聘市場, 我們可以問一下那些學生 -你平時在學校里是如何為將來的職業準備的?a) 不經過準備, 直接上b) 只學理論, 沒有實戰c) 用比實際工作要求更低的水平訓練d) 用和實際工作一樣的要求訓練e) 用比實際工作高一倍的要求訓練在這片神奇的土地上, 我們或許還可以聽到 f) 的回答:f) 我不用準備, 我爹叫阿剛。
如何判分「分, 分, 學生的命根。 」我在剛開始教這門課的時候, 我看到助教給同學們的作業判分是這樣的模式:最好的作業10分, 次好的9.5, 然後依次平滑下降, 有些學生交作業很遲, 有些學生寫的程序都不能編譯, 這些學生都得到6分左右。這樣的分數體系看起來非常和諧, 但這不是軟體業的實際情況. 我們任選一種軟體類型, 例如字處理軟體, 最好的軟體在市場上有多少份額? 第二名佔有多少? 第三名呢? 第四名? 誰知道字處理軟體市場的第四名是誰? 搜索引擎呢? 第一名的佔有率是多少? 第二, 第三, 第四呢? 第四名的軟體也是由優秀的軟體人員開發的, 他們也許加班更多, 那為什麼只有那麼少的份額? 這公平么?由於軟體市場有 」贏者通吃」 的規律 (第一名會佔據 50% 以上的份額), 我們在訓練中也要體現這一規律. 所以我規定:如果大家做同樣類型的作業, 則採用以下規則:完成質量在第一檔次的同學(一個或多個), 得滿分。完成質量在第二檔次的同學, 得 1/2 的分。在第三檔次的同學, 得1/3 的分數。以此類推…在很多作業中, 我或TA會寫一個比較平庸的解法 (例如用冒泡排序或線性查找)參加作業評比。 這個平庸的作業會得0分, 那比這個還差的作業, 就會得負分, 從-1, –2, –3 類推下去. 下面是兩個評分體系的比較:
這樣公平么? 很多人會問。 如果一個同學寫了沒有任何bug 的程序, 得到10分, 另外的同學程序有 1 個bug, 得到9.5 分, 程序編譯都不過的同學, 也得6分, 那你覺得這樣對寫了全對程序的同學公平么? 如果一個同學的程序連普通的冒泡排序都比不過, 老師和TA在花時間陪他玩, 他欠我們分數, 這樣的人不得負分得什麼?做中學上《現代軟體工程》 的同學, 都是大三到研一的同學, 應該具備基本的學習能力和開發能力, 軟體工程和其他類的工程 (如航天工程, 化學工程) 不一樣, 我們每天都可以用到軟體工程的產物 (軟體), 搭建, 學習一個軟體開發平台比航天化工要容易很多 (注: 在自家後院放二踢腳不是航天工程), 相關的學習資料也是非常容易獲得。 在這個情況下, 學生們可以在「做」的過程中學習, 這也叫」做中學」. 做了, 有疑問, 再問老師, 問專家, 這樣學習的效果會好很多。 我為這門課準備了三本課本, 一本指定的閱讀教材, 二十本參考書 (對, 20 本), 同學們平時可以多看書。真實的項目在這門課中, 我鼓勵學生做自己決定的項目, 但是要求他們要做」真實的項目」 – 有真正用戶的軟體。 那些 「經典」 的項目, 例如圖書館管理系統, 學生學籍管理系統等, 是不符合我的要求的。 項目要有活的用戶, 只有活的用戶才有活的需求, 才有活的場景, 活的測試用例。 只有活的用戶才決定同學們寫的軟體是否值得使用, 有些團隊寫的小軟體很好用, 在合適的用戶群中引起共鳴, 短短時間內, 就會有幾千到幾萬個用戶 (像北航團隊開發的魔方程序), 也有的團隊費了老鼻子勁, 寫出來的東西用戶量小於10, 自己團隊成員包括在內。 這些不同的用戶數量會迫使項目團隊反思當初在需求分析, 設計上的問題。 另外這門課並不是演算法競賽, 或者代碼集中營, 大家比的不是如何快速敲打出某個演算法, 而是如何在有限的時間內交付有價值的軟體給特定的用戶。 「真實」這一條件也促使大家做 「現實」的項目和項目管理。 很多學生有宏大的夢想, 但是在短短的 8 周團隊項目時間內, 甚至短短的 16 周課程時間內, 他們發現宏大的構想被自己程序的bug 搞得千瘡百孔, 轟然倒地。學生的收穫在這門課里, 有付出, 就會有收穫, 收穫體現在下列方面:寫出一個可用的, 有實際用戶的軟體。 這對大多數人來說, 是第一次。完整體驗軟體生命周期, 對於生命周期的各個階段有實際的了解。對於軟體設計有實際的掌握。 對敏捷軟體開發的具體技術有實踐能力。了解軟體團隊的各個角色, 和各個角色的互動. 對於其中一個角色有實際的深入體驗。學習如何與不同的角色打交道, 培養團隊精神, 學會解決衝突的幾種方法這個課程不講什麼? 這個課程不具體講某一個程序設計語言, 也不講 UML, 設計模式。 這些內容都應該屬於其它課程。但是從課後的自我反饋來看, 學生往往在某一門「程序設計語言」很有收穫, 為什麼呢? 第一是因為這門課的個人項目和結對項目讓他們有充分的機會學習和鞏固關於某一語言的知識; 另外, 他們第一次把某一門語言用到了一個有分量的實際項目中去, 從而深入地了解這個語言的特性。這可以說是<現代軟體工程> 的一個好的副作用。任何一門課都不會一帆風順地講下來, 所有人皆大歡喜。 老師學生需要時間來適應,交流, 才能逐步提高。 吹了這麼多, 到底學生反映如何? 下面是清華大學的學生對這門課的不記名評價。評分內容200720082009熱情、認真、投入、嚴謹,教書育人95.45±3.8095.00±3.4298.90±2.21講課思路清晰,重點、難點突出94.55±4.0489.29±5.7798.90±2.21講解生動、有吸引力,能激發學生的求知慾92.73±5.1590.71±5.3798.91±2.21師生互動,鼓勵學生質疑,並給予思路的引導94.55±4.0493.57±3.6998.91±2.21提供或推薦的教學資料有助於學生學習93.64±4.2386.43±8.1999.00±2.21作業等課程訓練有利於課程內容的學習94.55±4.0490.00±4.9599.00±2.21考核及評價方式能激勵學生主動學習與鑽研92.73±5.1587.86±4.8897.89±3.04注重學生創新意識和獨立思考能力的培養92.73±4.3791.43±4.4498.91±2.21對學生課外學習給予指導、建議92.73±4.3791.43±4.9299.00±2.21學習本門課程後有收穫92.73±4.3790.00±5.3897.91±3.04上好課很難, 老師, 學生都不容易,這個博客講了一些。一些學生清澈的, 充滿求知慾的眼神告訴我, 他們最關心的是 -怎麼用最小的代價, 讓我過了這門課!上了這門課就知道代價了。
推薦閱讀:
※關於軟體行業的思考和設想
※4.2 內聚和耦合
※為什麼軟體工程教科書上的內容和現實的軟體項目開發管理之間存在著一定差異?
※三十六計混lT公司
※The world at your fingertips - 天涯明月刀幕後8(重啟)