1. 什么是軟件開發(fā)?
軟件最基本的目標是讓計算機硬件(運算/存儲/輸入輸出)按照人們預(yù)想的規(guī)則來工作。我們又管軟件叫程序,軟件工程師定制編寫一個“順序、序列”,機器就按照這個序列來執(zhí)行。軟件開發(fā),就是這個定制編寫序列的過程。
2. 原本的樂趣:挑戰(zhàn)和控制欲
解數(shù)學(xué)題,是很多理科學(xué)生都很喜歡的一項活動。特別是在高中時期,證明出一道立體幾何或者在模擬考試中第一個交卷兒都是非常令人羨慕的,虛榮心和滿足感也會隨之飄飄然。同時,多數(shù)中學(xué)的老師和一些大學(xué)老師,喜歡把軟件開發(fā)歸于數(shù)學(xué)的范疇。按這個推理,喜歡數(shù)學(xué)的都應(yīng)該喜歡編程。但事實并非如此。
無論男性還是女性,我們都有控制的欲望。在控制不了“人”這種活物的情況下,能夠控制一臺機器讓他按照我們的意愿來運行,會帶來極大的快感。我30多歲了還喜歡玩遙控汽車,但一直羞于去玩具店購買,直到我兒子2歲以后。玩跑車,用手臂和腳尖控制一臺400馬力的怒吼的發(fā)動機當(dāng)然更加過癮,但顯然太昂貴了。編程則可能是達到這一目標最廉價又最冠冕堂皇的一種方式。而且編程這種活動似乎在發(fā)揮創(chuàng)造力和滿足自我陶醉心理上有更大的空間。同樣,現(xiàn)在的情況也非如此,越來越多的程序員開始不喜歡他的職業(yè)了。
擴展閱讀:單片機編程經(jīng)驗總結(jié)
3. 為什么軟件開發(fā)越來越無趣?
3.1. 首先,軟件開發(fā)并不是數(shù)學(xué)
我們在學(xué)校的時候,那些老師們把軟件開發(fā)歸于數(shù)學(xué)的范疇,這沒錯,但過于狹隘。在30年前數(shù)學(xué)或許是軟件的80%,但今天我們更傾向于把軟件開發(fā)稱為“工程”。工程與數(shù)學(xué)是不同的范疇,盡管在工程中我們會用到數(shù)學(xué),但并不是全部,而且在軟件工業(yè)的逐步發(fā)展的過程中,由于行業(yè)的分工進一步細化,數(shù)學(xué)的應(yīng)用在軟件工程中的比例越來越小。
算法是數(shù)學(xué)在編程中最基基本的一種表現(xiàn)方式,但在80%的軟件開發(fā)項目數(shù)百萬行代碼中,能真正讓你去思考“算法”的部分寥寥無幾。來自于“解題”的快感,自然無從尋覓。沒有挑戰(zhàn),哪來成就感?
3.2. 第二,軟件工程技術(shù)的發(fā)展,限制了施展的空間
計算機給程序員提供了一個廣闊的思維空間,但計算機工業(yè)則根據(jù)自己的發(fā)展需求將這個空間切分成非常細小的片斷。位于產(chǎn)業(yè)鏈上游和技術(shù)前沿的廠商、團體和個人通過中間件產(chǎn)品(如數(shù)據(jù)庫、應(yīng)用服務(wù)器)、開發(fā)工具、設(shè)計理念、框架、宣傳等方式則各自獨占了軟件技術(shù)鏈上最“有趣”的一部分。多數(shù)現(xiàn)代程序員,則隨流進入其它一個一個狹小的片斷中。那些所謂技術(shù)含量較低的管理軟件(廣義的業(yè)務(wù)軟件)領(lǐng)域,更是集中了大多數(shù)的從業(yè)者。
平臺、數(shù)據(jù)庫、應(yīng)用服務(wù)器、開發(fā)工具、現(xiàn)代軟件設(shè)計理念、軟件框架、技術(shù)宣傳,這些產(chǎn)品和理念在推動軟件工業(yè)成熟和發(fā)展的同時,一方面在宏觀上提高了整個行業(yè)的生產(chǎn)率,降低了技術(shù)門檻,吸引了更多的從業(yè)者;另一方面則在微觀上剝奪了多數(shù)程序員享受編程樂趣的環(huán)境。你應(yīng)用EJB或者SSH(struts/spring/hibernate)開發(fā)項目的過程中,由衷地體會到編程的樂趣了嗎?我反正沒有。
3.3. 第三,VB、PHP和Java
C語言是有趣的,因為它是“計算機科學(xué)”發(fā)展的產(chǎn)物。
Python和Ruby是有趣的,因為它是“天才”的產(chǎn)物。
Delphi是有趣的,因為他是史上“最優(yōu)美的結(jié)構(gòu)化編程教學(xué)語言Pascal”的延伸。
與之不同的是多數(shù)的資深程序員認為VB/PHP和Java是無趣的——
PHP是快速WEB生產(chǎn)需求催化的產(chǎn)物。VB和Java則是軟件工程發(fā)展的產(chǎn)物。
當(dāng)“編程”遇上“快速生產(chǎn)”和“工程”的時候,樂趣就開始退化了。然而與樂趣無關(guān)的是,他們?nèi)齻€卻成為了現(xiàn)代軟件工業(yè)中最成功的三把斧頭。一把能快速的砍出一個WEB論壇;一把能跨速的砍出Client界面;一把則通過理念、框架、規(guī)范、中間件等等等等,使得軟件開發(fā)更加模式化和規(guī)范化,令軟件行業(yè)向大規(guī)模工業(yè)化生產(chǎn)方式向前邁進了一大步。
VB、PHP和Java本身都是成功的,而陷于三者的程序員則多半難以成功。我們現(xiàn)在常常贊賞地說:XX技術(shù)XX框架讓程序員更關(guān)注于業(yè)務(wù)邏輯。我們在享受他們所帶來的便捷的同時,也正在慢慢喪失程序員的天性——創(chuàng)造力。
4. 尋找新樂趣之旅
我們不能選擇放棄,那么就讓我們開始去尋找新的樂趣吧!
4.1.創(chuàng)新:用戶UI體驗的樂趣
與20年前不同,當(dāng)年的軟件更接近“底層”,而今天我們所開發(fā)的軟件則更多地接近用戶的感官和操作。把成就感從底層的挖掘移向UI層的體驗,顯得順理成章。
同時,當(dāng)今的UI技術(shù)和硬件渲染能力非20年前可比。以我們目前接觸最多的WEB應(yīng)用為例,最為普通的HTML/CSS/Ajax/JS/Flex等技術(shù)為我們提供了全所未有界面表現(xiàn)能力。我一直堅信優(yōu)秀的用戶體驗是成功的一半。最近幾年的Web創(chuàng)新很多都集中在表現(xiàn)方式上,如Ajax和Flex。
一些小型的用戶體驗提升方式已經(jīng)普及到了“標配”的程度。比如,5年前如果你在一個Web表單中輸入了錯誤的數(shù)據(jù),必須在提交后的下一個頁面中被提示出錯;而今天不能在Input框的右邊提供實時交驗信息的界面則是令人惱火的經(jīng)歷。
在UI上的創(chuàng)新遠不止這些。在Ajax和Flash令界面表現(xiàn)的豐富程度達到VB/Delphi望塵莫及的今天,我們追捧著gmail,研究著google map,效仿著flickr,甚至崇拜著fins的GT Grid。一旦有人能夠向UI體驗發(fā)出挑戰(zhàn)性的創(chuàng)新,就會給開發(fā)者贏來眾多贊賞的目光和追隨者的效仿,伴隨而來的是開發(fā)人員極大的快樂。
4.2. 探險:扒開“框架”的樂趣
使用Hibernete談不上樂趣,至少是樂趣有限。但如果你扒開Hibernate的代碼,跟著作者的思路在數(shù)十萬行代碼迷宮中探險的時候,當(dāng)你撥開一層層迷霧,為一段思路一行程序一種理念一個技巧而拍案叫絕的時候,你可能會得到前所未有的樂趣:
這種樂趣可能,
來自于“發(fā)現(xiàn)”的驚喜,
來自于“理解”的激動,
來自于“學(xué)習(xí)”的充實,
來自于“頓悟”的爽快!
來自于“英雄所見略同”的自豪感!
在咱們軟件圈兒,大師用書說話,大俠則用代碼說話。“書上得來終覺淺,絕知此事要躬行”。轉(zhuǎn)進大俠的代碼里去吧,那里有無窮的樂趣等著我們。
4.3. 拓展:擴展眼界的樂趣
我一直鼓勵身邊共事的開發(fā)人員多學(xué)習(xí)一些編程語言,不一定在工作中用,但起碼能夠見識一下另一種思維方式。這不僅能擴寬眼界,我們更能從中體會到這個職業(yè)的樂趣。
出于管理上的效率和能力,5年來我們的團隊一直以Java為主,但從編程藝術(shù)的角度,我不喜歡Java。盡管我早就開始認識到軟件跟藝術(shù)風(fēng)馬牛不相及,但有時還會以這種欺騙自己的方式自我陶醉一把。
我不喜歡Java的原因是,這種一無是處而又無處不在的編程語言養(yǎng)成了我的惰性,讓我在工作中找不到去觸碰和學(xué)習(xí)Python和Ruby的“官方”理由。
有幸的是在過去的1年里我經(jīng)歷的三件事情重新點燃了我學(xué)習(xí)新的編成語言的激情:
* 12個月前,我因項目需要花費了整整1個月的時間鉆研Java。
* 5個月前,我因項目需要重新拾回了C語言(之前我已經(jīng)4年沒碰過make了)。
* 一星期前的一天,我無聊到把JE的Ruby論壇里的精華良好帖全部看了一遍。
試試吧,多學(xué)一種,我們一起學(xué)。
4.4.協(xié)作:大制作的樂趣
大師令我們敬仰,大俠令我們敬畏。那些底層的、抽象地、框架性的、被稱為無法重造得更好的輪子的作品,似乎只與他們有緣,給我100個腦袋,我也沒有信心去挑戰(zhàn)他們的領(lǐng)域。那么,好吧,沒骨氣就沒骨氣了,我們還有我們?nèi)〉贸删透械霓k法——協(xié)作。
鋼琴王子的獨奏固然經(jīng)典,氣勢磅礴的交響樂同樣能博得喝彩。跟交響樂一樣,軟件工程演奏的關(guān)鍵同樣是配合。
大制作的軟件產(chǎn)品是任何獨行俠無法完成的,一個人的精力有限興趣狹隘,不可能達到面面俱到,也懶于照顧上至UI體驗下至數(shù)據(jù)庫優(yōu)化的每一個細節(jié)。這正是我等發(fā)揮的樂園。
然而我不得不承認,在從樹上的猴子進化到鍵盤前的你我他的過程中,“協(xié)作”是我們退化得最迅速的優(yōu)良品質(zhì)。
如何在協(xié)作中取得成就感,獲得樂趣,正是我們現(xiàn)在不斷嘗試和孜孜追求的東西,它需要我們共同的努力。