2012年6月23日 星期六

轉帖超經典的一篇文章:一個普通IT人的十年回顧(2)

轉載的...尚未閱畢全文





2.編程生涯
讀研兩年半的時間,我四處打工,這兩年半我至少在七八家公司做過,編了十幾萬行代碼
,為自己賺了一台電腦,兩部手機(丟了一部),還有讀研期間的所有費用,實現了我的
目標:沒向家里要一分錢。
我水平不高,但在打工過程中,發現許多中國軟體公司的水平更菜!
2000年暑假,我參加一個商品軟體的開發,搬到了北大燕北園的一個宿舍,在那兒搞封閉
式開發。在這個項目采用VB6開發,主力程序員除我之處,還有一個華北電力大學的研究
生。大家都沒開發商品軟體的經驗,沒經過正式的設計,就匆忙編碼了。我曾經想采用分
層的系統架構,但遭到另一位程序員的反對,爭吵沒有結果,老板也不能做決定,結果各
行其是。現在看起來,那時真是太菜了,任何一本軟體工程書都會指出這種做法是不對的
我們直接就熱火朝天的干了起來,那位華北電力大學的老兄,真讓我佩服,他可以在一個
Sub過程中寫上2000行代碼!我覺得奇怪,為何他能寫這么多的代碼?一看,頓時我暈倒
,他居然將每個控制項的Left,Top,Width等屬性都用代碼來設定!想想這樣的程序,調試時
光單步執行就需要按多少次F8鍵!
我們在電腦旁邊搭了個行軍床,每天都是干到早上6點才睡,12點吃中飯,然後又是一個
通宵。當時整個工程只有一個類模塊,被我用於封裝訪問資料庫的ADO數據引擎,這是整
個工程中唯一一處用到了最簡單的面向對象技術的地方,然後,我寫了近十個Bas公用模
塊,每個模塊代碼規模都有一兩千行,還有十幾個窗體,每個窗體中都塞滿了事件驅動的
VB代碼,整個軟體應該有10萬行代碼,我一個人在此期間至少就寫了3萬多行VB代碼。程
序的主處理流程我甚至用ADO與DAO寫了兩套!
現在想起來,我們當時根本就不知道面向對象為何物,更不理解許多對軟體開發至關重要
的理論,就憑着一種熱情。在這段痛苦的開發經歷中,我不僅精熟了VB,而且從中學到了
很多。現在再開發同樣功能的東西。我至少可以砍掉2/3的代碼。怎么學都不如從失敗中
學得多。
後來我總結VB程序員的三個境界:
(1)所有代碼都只放在窗體文件中的,屬於菜鳥級,他們只會從面板上拖控制項,設置屬
性,然後再給事件編碼
(2)工程中有BAS模塊的,屬於中間級,他們已意識到有大量的代碼是重復出現的,應該
將其抽取出來作為公用模塊
(3)工程中有CLS模塊的,屬於高手,他們已掌握了面向對象的思想,並能應用這種思想
來解決實際問題
正是這次開發經歷,促使我反思:到底如何開發軟體?我個人可以用VB完成各種各樣的功
能,為什么湊在一起就會那么困難?更正一個BUG為何那么難?為什么一個看似簡單的軟
件,要拖半年的時間還看不到結束的日子?
九月,研究生要開題,我自擬了個課題:軟體體系結構設計。我決心弄明白,好軟體到底
是怎么做出來的。
我放下了VB,開始研究C++,原來學過VC,但沒學會,就直接從C++
Builder入手。Borland公司的VCL類庫讓我大為嘆服,很快就迷上了它,為此連帶學了Del
phi,並參與了一個Delphi項目。給我真正震撼的是《設計模式》這本書,看了才知道,
原來好軟體是這么設計出來的!在此,我強烈推薦所有有一定編程經驗的程序員一定要看
這本書!
一邊學習理論,一邊可沒忘記我沒經濟來源,於是又四處打工,接一些小項目與小模塊來
賺些生活費,國內一家橫跨家電與軟體的著名公司是我打工期間去過的最大的公司。但無
論什么公司,都給我一種感覺——爛!公司中充滿了對員工的剝削與不尊重,對軟體開發
這一事物的錯誤認識,管理混亂。
,但我所見到的軟體公司,我敢?我沒機會去外企,技術水平不到,別人不要我
說沒一家能做出世界一流的軟體!
我上的研究生課程也讓我失望,整個就是本科教育的再版。經過高考與考研兩次重大考試
,我對考試已是深惡痛絕,但讀研期間仍要考試,而且是閉卷!我就不知道我去背那些條
文對我的研究與學習有何幫助?2000年7月當我考完最後一門,終於大松一口氣,我終於
擺脫了考試的壓迫,可以在剩余的一年半中真正搜索我渴望已久的軟體技術了。這年,我
29歲。
悲哀嗎?一個中國的程序員要到29歲才可以真正自由地學習想學的東西!
我開始研究面向對象理論,看了大量的書,每天都在實驗室學習到深夜12點,天天上網,
CSDN成了我最常去的網站。
隨着我對軟體技術的了解越多,就越深刻地感到國內與國外技術水平的差異是如此的巨大
,巨大得甚至有讓人絕望的感覺。同時,在北京這個中國軟體人才最集中的地方,我也見
到了許多牛人,一個清華的本科學生,做程序員可以拿到一個月12000元的工資,一個北
大的計算機系研究生,一畢業就到外企,一個月一萬多收入,每年發16個月工資!干了兩
年就開了自己的公司。我看到了一個北方交大的本科生作品,在半年的業余時間里,用De
lphi寫了十幾萬行代碼,他甚至在代碼中嵌入匯編,自行編寫數據存取引擎讀寫Foxpro,
速度超快!軟體中有一個計算公式解析模塊,他用編譯原理理論居然做了一個小型的公式
解析器,就象C++編譯器檢查C++程序一樣,不僅可以判斷是否公式正確,而且給出的出錯
信息還相當准確!其基本功之扎實,水平之高讓我望塵莫及!中國優秀的人才真還是不少
的!在精英集聚的北京,面對着博大精深的軟體科學,我深感自身的渺小。
但我畢竟是靠自己奮斗出來的,我並不自卑,這世界需要牛人,同樣需要大批合格的勞動
者,我成為不了牛人,但我作一名程序員是合格的。
時間過得飛快,一年半根本就不算時間,馬上就要畢業了,學習的成績如何,要到社會上
去競爭了,讓社會考場來決定你是否及格。
3.畢業求職
98級的研究生是IT業最後輝煌的回光反照。當時,各大公司都發了瘋似的要人,象華為,
當時是來者不拒。計算機專業的研究生是一搶而光,本科生也供不應求。2001年畢業的我
的師兄師姐們,平均每個人手頭都至少有兩三個Offer,談的工資沒有低於每月6000的,
許多人去了外企,工資在8000~10000每月的也有。真是畢業生的黃金時間。
但好景不常在,911事件我看來好象成了分水嶺,911之後,整個IT業急剎車,就業形勢急
轉直下,各大公司都在消化去年吃得過飽的胃口,我形容是大家都吃壞了胃,再也不可能
有我師兄師姐們的風光了。雖然時間相隔僅大半年。
從10月開始,11月和12月,我幾乎是在招聘會與公共汽車上渡過的,北京東南西北地去面
試,上午在上地,下午可能就要跑到朝陽區,疲於奔命。
在找工作過程中,我良好的心理素質與豐富的編程經驗起到了很大的作用,並沒有遇到很
大的困難,就先後有幾家公司表示要我。
其中我想說的有兩家公司。
一家是台灣公司,應該說他們做得是不錯的,但我非常反感他們那種自認為高於大陸人的
那種優越感,而且待遇也不高。面試之後,回來感覺很不好。當時台灣是民進黨上台主政
,我就稱之為“民進黨”看不起“共產黨”(雖然我不是黨員,但我們都是中國人,都希
望中國能強大,讓她的人民能挺直腰桿)。
我想:我們大陸確實是不如台灣發達,難怪別人看不起我們,這世界勢利得很,社會如此
,國家亦然。但我中華960萬平方公里的國土,13億人口,難道要依靠一個小小的島嶼來
撐門面?難道除了台灣公司,我就無處可去了?雖然改變不了什么,但我決定絕不去台資
和日資的公司工作(日本人我更不喜歡,但我認為他們做事實在優秀,我們一定要向日本
人學習)!在這種公司呆着,不爽!同時,我們的確也得爭氣些,這世界只尊重強者。
另一家是個很不錯的民族軟體企業,想要我,其老總專門找我去面談了一次,希望我能到
他的公司工作。這位老總白手起家,能在五六年的時間內由幾個人發展到300多人,當時
,是中國這個領域軟體市場占有率最高的公司,我非常佩服,他為人也很好,並表示可以
給我每月比其他研究生多加1000元工資,而且希望鍛煉一兩年之後我能夠帶領一個團隊來
開發產品,並負擔我畢業所需交納的各種費用。在就業不景氣的2002年,對我一個30歲的
技術水平有限的老程序員如此看重,真叫我感動。雖然我最後還是沒去,但我仍然對這個
公司充滿了好感。一個軟體企業最重要的是什么?是對人的尊重,沒有這點,可以斷定,
這個公司長不大。
我為什么沒去軟體公司?放棄有可能在幾年之後年薪突破10萬的收入?是因為我已有了更
想做的事,我想當老師!
我自己是從自學的路上走過來的,其中的艱辛歷歷在目,無人指點,我走了多少彎路?中
國還有多少是象我這樣的年輕人無人指點的?我幸運能爬出來了,因為我至少還能有飯吃
,比我條件更差的,比如農村的孩子,可能就被生活的壓力所淹沒了。我個人的力量很微
弱,技術也有限,但我自認為至少是一名合格的程序員,如果能培養出一大批達到我的水
平的學生,他們畢業後成為合格的程序員,中國軟體的根基就會更扎實,如果更能有一批
遠遠超過我水平的學生出來,中國軟體就有希望了。軟體是什么?軟體以人為本!
人生追求什么?金錢?我很缺錢,但不可能把金錢作為我的目標,我希望我能夠成為一個
對社會有所貢獻的人,能夠獲得心靈的充實,於是,我選擇了留校。
4.對教育的反思與教書生涯
2002年下半年,我參加了北京高校青年教師崗前培訓。一位杜教授的兩堂課讓我印象深刻
,其中兩句話讓我深深震動:
第一句話:我是一個教書匠,教書匠好啊,好就好在“匠心獨運”!
第二句話:做什么工作都要達到變魔術的境界!
是的,作為一名教師,就必須起到一個傳聲筒與放大器的作用,將人類最聰明的人探索世
界所得到的知識予以拓寬發展,以便讓更多的人能夠掌握這些知識並進而應用於實踐,從
而推動人類的不斷進步。
作為一名計算機專業的教師,就要努力把先進的計算機技術以盡可能高的效率傳授給廣大
的學生,引導他們直接面對真實的軟體世界,而不是向他們硬灌各種各樣的理論知識,強
迫他們去死記硬背以應付考試。
我是一個小人物,才低學淺,但我真的認為高校計算機教育存在嚴重的問題。我在打工期
間的開發經歷,以及閱讀國外相關資料的時候,發現學校中教的和社會上用的差得太遠!
都已經是什么時代了,許多大學還設立Foxpro課程,難道就不能直接用現代主流的資料庫
如Oracle,SQL Server,哪怕是Access也好,來講授資料庫知識?還有所謂的計算機等級
考試,呵呵,過了三級學生的我見過不少,但他們真正對軟體,對計算機又理解多少?
在中國甚至於升職稱也要考計算機,我看了一本職稱計算機考試教材,里面幾乎原樣照搬
計算機原理課程中的相關章節,弄得我給搞藝術的大嫂講了一個小時的二進位與八進位、
十六進位的轉換方法,她還是弄不太清。我都泄氣了,對啊,他們搞藝術的,有必要去分
清二進位的10與十進位的2有何分別嗎?他們八輩子也用不上。但是考試用得上,呵呵,
又是中國特色。
拿C++來說,我講過C++課,許多的國內教材對C++語法下了大功夫,卻對體現了C++精華的
STL只字不提,對代碼背後所體現的軟體開發思想與方法更是視而不見,我用C++也編過不
少程序了,說句實話,我用到的特性不到C++的三分之一!於是就出現了這種怪現象,許
多學生考試可以拿八九十分,給他一個簡單的實際問題他卻不知如何下手!
還有UML,現在好象很火的樣子,我們讀研時就開了這門課,講句實話,當時這門課我就
沒聽懂,可後來我嘗試着用C++用面向對象的方法來編程序,然後,由代碼倒推回UML類圖
,一下子就明白了,原來UML只不過是一種描述面向對象系統的符號罷了,如果學生沒進
行過真正的OOP,那就是為了學UML而學UML,根本就本末倒置。
還有軟體工程,我的感覺,一個人如果沒寫過一萬行以上的程序,他看軟體工程書就同看
政治書差不多,每句都對,呵呵,就不知道為什么對。我完成了那個幾萬行的VB程序之後
,再回過頭看看理論,真是句句是真理!每個理論背後都是大量實踐經驗的總結。
回想我做軟體的體會,我發現所有的知識都是一個完整的體系,根本就無法區分哪些知識
是本科的,哪些知識是研究生課程。於是,一種想法產生了,我主講程序語言類的課程,
那我就直接以真實的軟體開發過程為主線,實踐中需要什么我就講什么。講C++/Java,我
就拋開了指定的教材,C++我講了STL,Java我講了OOAD,兩者我都講了用Rose進行雙向工
程,引導學生去學UML,一開始就用UML去描述自己開發的程序,何必浪費大量的時間去學
結構化的編程方法?
我現在簡直成了面向對象技術的布道者,我下學期即將開設OOAD基礎選修課,從實際項目
中抽取典型的案例,講UML,講Rose,講設計模式,講軟體體系結構,例子代碼橫跨C++/J
ava和.net下的開發語言(C#和VB.net),這對於我一個技術水平有限公司的董事長而言
,實在有點不自量力,我鼻子上才插上幾根蔥,就想裝大象?但我想,如果我能成功地激
發出哪怕1%的學生的興趣,能引導他們走向我認為是正確的方向,能啟發他們思考,能直
接面向真實的軟體開發活動而不是學校的考試,就是我的成績。我現在正在看引進的原版
書籍---《設計模式解析》,時時擊節贊嘆!《設計模式》經典但難懂難用,而《解析》
一書的兩位作者既有豐富的從業經驗,又對OOAD進行了深入的思索,真知灼見時時展露於
書中,我現在剛看了這本書的80%,基本上可以用一個成語來描述這部書:深入淺出!
要做到深入淺出談何容易!只有同時具備技術專家與文學作家素質的人才能做到!
反觀我們國內的大量教材,還有大量的垃圾論文(包括碩士,博士的,本科的就算了,我
看絕大部分根本不能稱之為論文),全都是“淺入深出”,作者自己都未必明白,就東拼
西湊,擺出個樣子嚇人。本來完全可以用大白話三言兩語講清楚讓人明白的道理,有人專
門要繞一大圈,專挑用高深的數學公式來表達,唯恐別人容易理解,顯得他水平不高!呵
呵,什么東西一沾上“數學”,立馬身價百倍。我就聽過一個北師大的一個在讀博士說過
:如果一篇博士論文中沒有一個數學公式,根本就不算是博士論文。這句話對不對,大家
可以多思索。我數學不好,沒資格討論數學,我的直覺:數學是工具,但如果為了發表論
文等目的而故弄玄虛,為數學而數學,是不合道理的。中國的學術水平與現狀,大家都心
知肚明,不用我廢話了。
現在每年都畢業大批的計算機專業學生,可其中真正具備扎實根基的可以很快勝任工作的
我看只有5%(95%的學生不要扁我,不同意就當我在說胡話,我很瘦的,一扁就沒了?
14;)。多年以來,我國高校計算機教育是按照計算機科學研究者來培養的,可事實上,
有多少學生能從事計算機方面研究的能力?我看應分流,80%的學生按工程師方向來培養
,20%的學生按研究者方向來培養,而且應大幅減少必修課的數量,計算機領域太深太廣
,樣樣都想教給學生,反而成了夾生飯,一個想從事硬體設計的學生和一個想從事軟體開
發的學生,能給他們一樣的飯吃嗎?學校應提供各種條件和資源去引導學生,激發學生的
創造性與主動探索性,讓他們去嘗試,去發現自己的長處,最終找到最適合自己的發展方
向。不這樣做,中國軟體後繼乏人,沒希望。
5.實踐第一
2002年下半年,我和一個朋友去了北京郊區的一家雜志社,看到的情形讓我震驚:在信息
產業最發達的北京,這家雜志社還用人工查對雜志訂單和款單,看着那按省來登記的幾大
本厚厚的客戶登記本,工作人員需要手工來在其中查找相應的信息。這樣的工作效率,這
樣的行業信息化水平!北京如此,全國又如何?
從這件事上,我看到了中國軟體業的另一方面。一方面我們沒有核心技術,另一方面,已
有的技術又根本沒推廣沒用好。追蹤世界先進水平,對於我等這種水平的人來說,確實勉
為其難,但將已有的技術用於解決實際問題,卻是我們可以做的。如果中國各行各業都真
正能通過進行信息化而提高生產效益,那中國不就從根本上強大起來了嗎(象印度,IT一
枝獨秀,其他行業沒有起色,我稱之為跛足的國家,絕不能成為世界強國)?在扎實的社
會基礎之上,軟體業不就有了更大的市場與發展潛力?中國許多行業的信息化水平非常低
,而且中國地域廣大,發展非常不平衡,有些地方信息化水平甚至為0!努力推動行業信
息化,是我們這一代軟體開發者的責任!而追趕國外先進水平,恐怕就不是一代兩代程序
員可以達到目標的,需要長期的努力。作為一名軟體開發者,只能腳踏實地,哪怕你只做
一個小小的MIS產品,也要盡力把它做好來。
於是,我開始了期刊發行系統的開發,這完全是自發的,沒有任何資金投入,只有一種熱
情在支撐。我開始選擇C++ Builder開發,做了幾個月,完成了第一個版本,但我發現,
我找不到足夠水平的C++程序員進行合作開發,而且整個一個EXE文件,在體系結構設計上
雖采用了分層分塊的設計方案,但卻是源代碼級別的,要拆分成COM組件難度太大,不是
一個人能完成的,於是中途流產。
2003年3月,我開始系統地學習.net,我吃驚地發現,我原來想在C++中實現的許多功能,
比如對象串列化為XML,在.net中已有現成的類可用,.net更把OO的功用發揮到了極致,
它的混合語言開發,它的反射機制,它的新的自識別的軟體組件,以及強大好用的開發環
境VS.net,都讓我驚嘆微軟對開發者遇到的困難的深入把握,相比用C++開發,至少可以
提高1/3的開發效率。於是一個新的想法產生了,我要把以前的產品用.net重寫,利用.ne
t強大的組件模型,將設計模式理論推廣應用到組件級別,通過XML和反射機制建立一套可
動態裝配的軟體生產流水線,實現象Dell直銷PC那樣的軟體動態裝配直銷。只要建立好靈
活可不斷重構的系統架構,配以對業務領域的深入分析,逐步建立功能強大的業務組件倉
庫,就可以實現軟體系統的動態裝配。說干就干,我用VB,net重寫了原先用C++編寫的系
統,將原先的一個EXE變為十幾個DLL,而且這些DLL還會隨着發展而不斷地分裂,也有可
能重新組合,利用Refractoring(重構)不斷進化,最終形成一整套完備的行業軟體組件
庫。做軟體關鍵因素是變化,只有適應變化的系統才是有生命力的。
我用兩個月的時間大體上弄清了.net平台下的主要類庫,然後又用兩個月的時間再次重新
實現了期刊發行系統的C++版本的全部功能,到8月份我寫這篇文章之時,第一個產品里程
碑已經完成。同樣的,除了需求是由另一個合作者去搜集的之外,幾乎又是全部由我一個
人包攬了所有的系統設計及編碼工作!
毫無疑問,我自覺得新系統要比老系統可維護性強得多,真正實現了徹底的全組件化系統
開發,計劃再有一個月的界面美化,改正Bug,引用多線程提高運行效率,優化系統結構
,就可以提供給用戶試用了。市場如何,難說難測。
在開發過程中,我再次感到巨大的挑戰,不光是技術上的,更是管理上的。人才是我最頭
痛的問題,沒有一流的人才,哪來一流的產品?我們找不到足夠水平的程序員一起合作(
牛人哪屑於做這樣一個小兒科的產品?)我們要走的路還很長。也許我們開發的產品是失
敗的,但我從來就沒指望能用這賺錢,我只是盡一個軟體開發者的責任而己,成敗已不重
要!人生不嘗試,怎能體現人活着的價值?

結束語 永無止境的軟體之路
1.辛酸與苦辣
做軟體開發很苦的,技術進步如此神速,每個軟體開發者都得不斷地學習以跟上發展的步
伐。有時我常想,何苦呢?我現在在大學中混,怎么樣不能混下去?為什么要做這些吃力
不討好的事?我投了十年的時間去學習電腦,卻最終發現自己不過中人之資,離頂峰遠之
又遠。古語雲:三十而立。我今年32了,仍是孤身一人,看看周圍的同學,他們的小孩都
差不多上小學了!許多都有了自己的房子和車子,而我到現在才開始申報中級職稱,還擠
在集體宿舍中,望着北京高昂的屋價而嘆息。現在社會越來越功利了,看着象我這樣的窮
光蛋,看着由於長期面對電腦缺少鍛煉而瘦弱的身軀,又有哪個女孩願意嫁過來受苦?
軟體人的生活很苦,壓力很大,我認為是拿青春賭明天。就是在這種惡劣的開發環境中,
還有許多業外人士指手劃腳說程序員如何如何,還有太多的公司只顧壓榨程序員的勞動,
缺乏對程序員基本的尊重,怎不叫人寒心?
“三十而衰”,這句本不應該流行的話居然成了中國軟體人員的流行語。中國程序員的悲
哀!
2.無止境的追求
人類已進入信息時代,計算機技術幾乎每隔半年就有一次大的變化,我現在又面臨着這樣
的抉擇:今後的路如何走?
北大的教師聘任制度的改革一石激起千層浪,說明了中國高校的改革勢在必行。我是歡迎
這種變化的,雖然到時我可能會下崗。但人生中總會遇到各種各樣的挑戰,只要你不倒下
爬不起來,就有希望。
我想我必須再次讓自己有個提升,要從小事做起,但做小事則絕不能成為最終的目標,也
許,不遠的將來,我會走出國門,到世界軟體技術最發達的地區去汲取豐富的養份。今後
的路怎么走,我還在摸索之中。
3.人生無悔
人生年華如水,時光無情。在過去的歲月中,我盡了自己的力,回顧往事,我可以說:過
去的事只有遺憾,卻沒有後悔。如果給我再一次選擇職業的機會,我還會再次選擇軟體!

再過10年,到2013年的時候,我也許會再次寫一篇人生的十年回顧,到那時中國的軟體會
如何?中國軟體的明天靠你我這些普通人去扎扎實實地去工作來支撐!少發些牢騷,多做
些實事,中國軟體才會有光輝的明天。你我共勉!

沒有留言:

張貼留言