當(dāng)前位置:首頁 > 充電吧 > 充電吧
[導(dǎo)讀]本文是小編在FB看到的,覺得挺有意思的,應(yīng)該是很多公司或者軟件工程師都會(huì)遇到的,特地轉(zhuǎn)過來分享給大家。

本文是小編在FB看到的,覺得挺有意思的,應(yīng)該是很多公司或者軟件工程師都會(huì)遇到的,特地轉(zhuǎn)過來分享給大家。

我們公司的 Windows 版軟體已經(jīng)有十多年的歷史,經(jīng)過歷代工程師的整治之后,內(nèi)容已經(jīng)凌亂不堪。過去三個(gè)月,我找時(shí)間自己重寫了整個(gè)主程序。原本數(shù)萬行的程序,被我重寫的只剩下數(shù)千行,功能不變,效能更好,而且架構(gòu)儼然。

前幾天完成 Alpha 版之后,我不禁開懷大笑,笑聲驚動(dòng)整個(gè)辦公室。

在重寫這個(gè)程序的這段期間,前兩個(gè)月,我每周花在這個(gè)程序上的時(shí)間應(yīng)該不會(huì)超過四個(gè)小時(shí)。后來我趁著農(nóng)歷新年沒事干,跑到公司加班數(shù)天,但是一天寫程序的時(shí)間也不會(huì)超過四個(gè)小時(shí)。

通常我白天寫兩、三個(gè)小時(shí)的程序,遇到瓶頸就去忙別的事,或者干脆回家吃晚飯,晚上睡覺前,躺在床上用手機(jī)查一下資料,第二天上班走在路上,就會(huì)很自然的想到不錯(cuò)的解法。

寫程序是一種創(chuàng)作,不是做苦工,不能每天在電腦前面枯坐十幾個(gè)小時(shí),否則超時(shí)工作,只會(huì)讓自己的腦筋變得更糊涂。

我所認(rèn)識(shí)的許多寫程序高手,每天寫程序的時(shí)間都不會(huì)太長。

1995 年的時(shí)候,有一天在美國鹽湖城,我陪著趨勢科技的創(chuàng)辦人張明正扶著他爸爸過馬路,他突然跟我說:「宜敬,我實(shí)在搞不懂,在軟體這個(gè)行業(yè),一個(gè)優(yōu)秀的工程師的產(chǎn)出可以輕易抵得上一、二十個(gè)平庸的工程師,但是公司最多只要付他兩、三倍的薪水。那為什么還有公司愿意付錢雇用那些很平庸的工程師呢?」

當(dāng)時(shí)我博士剛畢業(yè),當(dāng)然不知道要如何回答他的問題;而現(xiàn)在過了這么多年,我還是不知道要如何回答那個(gè)問題。

而當(dāng)時(shí)張明正會(huì)問我那個(gè)問題,應(yīng)該是因?yàn)槲医榻B了幾位同學(xué)跟朋友到趨勢科技工作。那幾位都是以一當(dāng)十、以一當(dāng)百的高手。趨勢科技當(dāng)時(shí)沒有給他們十倍、百倍的薪水,但是對他們也不薄,給了他們不少的股票。

后來趨勢在日本上市,我那幾位朋友都成了億萬富翁,財(cái)富應(yīng)該超過一般工程師的十倍、百倍吧?

寫一個(gè)大型程序,并不是「人多好辦事」。

如果是土木工程或是制造業(yè),人越多、產(chǎn)出就越大。如果一個(gè)計(jì)畫延誤了,就多調(diào)一些人手過來幫忙。

但是在軟體工程里,人越多,就越是難以協(xié)調(diào),寫出來的程序也往往品質(zhì)越差、效能越糟糕。

這就是有名的”The Mythical Man-Month: Addingmanpower to a late software project makes it later"。

IBM在1960年代開發(fā)OS/360作業(yè)系統(tǒng)軟體時(shí),就發(fā)現(xiàn)了這個(gè)奇特的現(xiàn)象。

所以我也搞不懂,大型軟體公司雇用了那么多的軟體工程師干嘛?

我在當(dāng)兵的時(shí)候,有一陣子在臺(tái)中十軍團(tuán)的資訊中心擔(dān)任資訊官。那時(shí)候我手下有兩名資訊科系畢業(yè)的大專兵,但是我嫌他們兩人寫程序?qū)懙奶?,而解釋給他們聽更是費(fèi)事,還不如我自己動(dòng)手寫比較快。

所以我就叫他們到一邊涼快,所有的程序都由我來寫就好。而他們兩人覺得很不好意思,就泡了很好喝的奶茶給我喝。

后來我們成了很好的朋友。

寫程序并不是寫的越長越好、越厲害。

我年輕在臺(tái)大資訊工程系的時(shí)候,會(huì)跟朋友炫耀說:「我寫的程序語言編譯程序,總共有一萬多行耶?!?/p>

后來我去美國布朗大學(xué)讀電腦科學(xué)博士,畢業(yè)的時(shí)候喜歡跟朋友炫耀:「我的博士論文那個(gè)程序,功能那么強(qiáng)大,但是我只用了七、八千行程序就搞定了耶。」

二流的軟體工程師,喜歡把簡單的問題弄的復(fù)雜,寫出別人看不懂的程序。

一流的軟體工程師,喜歡把復(fù)雜的問題簡單化,寫出架構(gòu)清楚明白的程序,讓人看了之后,覺得問題好像很簡單。

三流的軟體工程師會(huì)去崇拜二流的軟體工程師,因?yàn)樗麄儠?huì)覺得二流工程師寫的程序都看不懂,一定是超級(jí)厲害;

三流的軟體工程師不會(huì)去崇拜一流的軟體工程師,因?yàn)樗麄儠?huì)覺得一流工程師所做的事情都很好懂,好像都很簡單。

只有一流的的軟體工程師才會(huì)佩服一流的軟體工程師,因?yàn)橹挥兴麄儾拍芸吹某鰜恚渌囊涣鬈涹w工程師厲害在哪里?

臺(tái)灣的軟體業(yè)如此,美國的軟體業(yè)也大致如此。

直到1980年代末期,IBM一直是世界上最大的電腦公司。而當(dāng)時(shí) IBM 找了一些原來是做硬體制造的高階主管來管軟體部門。

那些高階主管依照他們管理制造部門的經(jīng)驗(yàn),決定用KLOC (thousands linesof code),也就是每位軟體工程師每年寫出多少行程序來計(jì)算軟體部門的效率。

結(jié)果軟體工程師們都「短話長說」,寫出一堆落落長又沒有效率的軟體程序。

要成為一流的軟體工程師,必須熟悉了解電腦科學(xué)的各種基礎(chǔ)理論,也必須累積長時(shí)間的實(shí)務(wù)經(jīng)驗(yàn)。

我在布朗大學(xué)電腦科學(xué)系讀博士修課的時(shí)候,程序作業(yè)的份量非常重。上作業(yè)系統(tǒng)(OperatingSystem)課的時(shí)候,教授要我們每個(gè)人獨(dú)立寫一個(gè)包含F(xiàn)ile System與 Process System的迷你Unix作業(yè)系統(tǒng);

上編譯程序(Compiler)課的時(shí)候,教授要我們每個(gè)人獨(dú)立寫一個(gè) Compiler,而且每一個(gè)模組還必須用兩個(gè)以上的方法寫,然后互相比較;

而上 Andy Van Dam 教授的電腦圖學(xué),那簡直就是人間煉獄。當(dāng)時(shí)助教發(fā)問卷調(diào)查,發(fā)現(xiàn)每位學(xué)生每周花在寫那堂課的程序的平均時(shí)間超過四十個(gè)小時(shí),學(xué)生們幾乎要群起造反。

但是修過上述那三門課而沒有被當(dāng)?shù)簟⒂帜酶叻值?,就成了懂理論又懂寫程序的高手、高高手?/p>

當(dāng)年我在布朗大學(xué)讀博士的時(shí)候,我估計(jì)我們系上像我這種等級(jí)的寫程序高手,大概有十來個(gè)吧?

但是我們系上公認(rèn)最厲害的寫程序高手,還是我的指導(dǎo)教授 Prof. SteveReiss。他一個(gè)人大概抵得上五到十個(gè)我們這種等級(jí)的工程師。

關(guān)于他的傳說很多。有一次我去他的辦公室找他,看到他正在玩接龍游戲。他被我發(fā)現(xiàn)了,有點(diǎn)不好意思,趕緊跟我說,他覺得 Windows 上的接龍游戲很好玩,但是他沒有 Windows 電腦,所以就花了四、五天,利用零散的時(shí)間在他自己的 Sun Work Station 上面寫了一個(gè)類似的接龍游戲,包含彩色的圖像接口等等。

想玩電玩就自己寫一個(gè)?我很想笑,但又差點(diǎn)在我?guī)煾该媲肮蛄讼聛怼?/p>

十一

我在布朗大學(xué)認(rèn)識(shí)的那些軟體高手,后來真正以寫程序?yàn)橹緲I(yè),然后寫出偉大又廣泛被使用的程序的,應(yīng)該不多。

因?yàn)橛行┤撕髞砣ギ?dāng)大學(xué)教授,教授通常是不會(huì)自己寫程序的。久了之后,我不知道他們的功力剩下多少?

有些人后來為了拿高薪,去一些大公司寫一些很沒營養(yǎng)又很無趣的程序。久了之后,我不知道他們的功力剩下多少?

有些人后來進(jìn)入產(chǎn)業(yè)界工作,沒多久就升上了管理職,而管理職人員通常是不會(huì)自己寫程序的。久了之后,我不知道他們的功力剩下多少?

所以程序高手原本就不多,而一直繼續(xù)在寫程序的程序高手就更是稀有了。

十二

美國的軟體業(yè)有一個(gè)老笑話:如果有兩個(gè)工程師在同一個(gè)團(tuán)隊(duì),一個(gè)很會(huì)寫程序,另一個(gè)很不會(huì)寫程序,那后來升上經(jīng)理的,一定是那個(gè)不會(huì)寫程序的。

因?yàn)閳F(tuán)隊(duì)需要那個(gè)會(huì)寫程序的留下來寫程序。

十三

我寫程序的功力最高的時(shí)候,應(yīng)該是二十多年前我剛拿到博士的時(shí)候,那時(shí)候我又懂理論、又累積了大量的寫程序經(jīng)驗(yàn)。我不敢說自己能以一當(dāng)百,但是以一當(dāng)十應(yīng)該是綽綽有馀的。

只可惜,沒多久之后我就升上了管理職,而當(dāng)上了經(jīng)理、協(xié)理、總經(jīng)理之后,如果還自己寫程序的話,那是會(huì)被別人笑的。

所以我就不再寫程序了,而且我也學(xué)會(huì),要在自己的部門多擺一些工程師,否則陣仗不夠大,會(huì)被別的部門瞧不起,也會(huì)被我的上司瞧不起。

二十年下來,我的功力大概只剩下兩三成。

十四

我現(xiàn)在終于自己當(dāng)了老板。而當(dāng)上了老板之后,最大好處之一,就是我高興寫程序就可以寫程序。就算有人要笑我,我也可以不理他們。

十五

我趁過年期間重寫了我們公司的 Windows 主程序,完成之后,自覺功力已經(jīng)恢復(fù)到當(dāng)年的三、四成,不禁大樂。

不過我還是覺得,軟體工程還真是一門很難以理解的行業(yè)。雖然我本身就是一個(gè)軟體工程師,雖然我的博士論文研究的就是程序開發(fā)環(huán)境(Programming Environment),主題就是我在這邊所說的這些問題。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉