致青春
還記得自己那年考清華失敗,被調劑到中科大軟院,當初有幾個方向可以選,軟件設計、嵌入式、信息安全等等,毫不猶豫地選擇了信息安全。
為什么選信息安全?這四個字聽起來多牛多有感覺,我本科是學物理的,記得做一個光學實驗的時候,一個老師看我做的結果,說,學物理不是什么人都可以的,這個是需要一點智商的。
好吧,當初其實并非對我一個人所說,但我確實感覺到受到了鄙視,同時,我沒有任何在物理上的精湛技藝可以反擊我的老師。
由于整個大學期間,我都在沉迷游戲和小說,以至于輔導員說,現在找你都得預約。
而我的同學基本在學期開始和考試前能見到我,當時為了應付考試,我不得不學習復雜的物理公式和推導,有一門課程是激光原理,老師是雙博士學位,大概是很厲害的,在我考試時,過來看我的卷子,說你的”背功“很厲害。
考試時如期通過,但老師大概都對我評價不高。自然,我是感到不愉快的。
回到我的畢業論文,大概是做一個電離層特征參量的反演,其實就是用迭代法解病態方程。
這個論文基本是沒有人選的,因為題目本身可能相對比較難,也需要編程實現,好吧,當時下載的是盜版的matlab,參考的是一個日本學者和我導師的論文,鏗鏗鏘鏘地寫出來了。還做了個所謂的參數優化,以使得結果看起來更平滑。
當時覺得很得意,我女朋友(現在的老婆)也很驚訝,我一個月做完了。
其實這不是第一次領略程序的魅力,在很久之前,高中時期,為了追一個女生,我做過flash,當時我就覺得拖來拖去很麻煩,但苦于沒有基礎,看不懂actionscript,所以難以深入體會編程的精妙,如果看到網上有一些類似雪花飄落、旋轉字等效果,都是直接拷貝修改到完工。
現在回到,為什么選擇信息安全上來,因為在大學時,很喜愛游戲,尤愛單機,國情大家是清楚的,而且我沒有錢,也不知道哪里可以買到正版,這個猥瑣了,呵呵。
仙劍、上古、火炬之光、火焰紋章,各種類型都喜歡。也很喜歡生存類游戲。給一個單機游戲做的exe補丁和用lua拓展的mod至今看來仍讓我懷念。
討厭網游是因為自己沒有錢,搞不過RMB玩家,而且砸裝備總失敗。
唯獨一個,2006年時,我玩完美世界,后來玩它的SF,為了砸裝備,我第一次想到寫封包外掛,由于當時已經有一些socket、tcp/ip的概念了,雖然C++玩不轉,還是各種參考,寫hook、寫字節轉換,同時完美當時打擊WG很厲害,游戲基址容易變,又加了很多防調試的功能。
但為了不手工砸裝備(SF里的石頭幾乎免費,就是砸上去的幾率太低),我欲望那個強啊,所以用OD調試找網絡發送的函數地址, 然后C++寫代碼hook。
程序最終工作很好,我還分享給了幾個玩友。
后面也寫過一些類似跳舞自動擊鍵的WG,主要也是為了自娛自樂,因為我真的反應不過來屏幕上瞬間出現太多的key!
與程序為伍的日子很少,但每一次接觸,似乎都是為了達到自己的一些目標。
所以凌亂的編程體驗,雖然不系統,不精湛,卻讓我快樂。
再次回到為什么選擇信息安全上來?也許答案已經很清楚。
當時覺得虛擬機加密太高深了,聯網解密也難搞定,所以覺得信息安全一定是能解決我的問題的!
后來你猜到了,就是C,就是匯編,就是linux,我當時是多么反感linux,當時還用的是ubuntu,但為了課程,實在是沒有辦法,為了考研,自己系統自學了數據結構、計算機網絡、操作系統、組成原理,當時在考研論壇上還和一個清華搞計算機體系的探討問題,刷了好幾頁的帖子,現在看來,多幼稚!但,快樂也是固定在那個過程之中了。
我討厭匯編,我討厭C,我討厭linux,但他們強大,能夠滿足需求,這就夠了。
其實這不應該是我們真正的主題,而且入了行的也很少會java還是c#這么比,但初學的,java和c#往往就代表了兩大流派,java代替了j2ee,c#代替了.net,ok,沒有關系,這么作為title,不影響我們說事。
如果從語言的角度上來講,c#毫無疑問勝出,易用、門檻低、優雅、較為簡潔。但java和c#的語言特性是相似的。
c#出現的時間比java晚,所以自然吸收、借鑒,同時又有它的創新,比如很早就支持lamda表達式、比如event和委托,比如var,比如linq。
但如果從面向接口來講,java同樣可以做到event和listener,只不過對象引用的傳遞比較直接。
而.Net的類庫和jdk則各有千秋。
如果從應用的角度來看,javaee和.Net體系幾乎都涵蓋了主流的開發方向:
桌面、Web、服務端、數據庫、網絡、移動端、中間件。
哪個方向,哪個更強?這個留給讀者自己體會吧。
微軟給.Net一個宇宙最強的IDE,也給了各個方向統一而平滑的編程體驗,不得不說,微軟的上手要容易的多。
而java則一開始就和開源分不開,多如牛毛的框架、引擎、包,blabla,用java開發,程序員要懂得東西更多一些。應為你大部分情況下得自己整合。但整合的好了就是很強大的,比如SSH。
在近幾年很熱的大數據和云計算領域,hadoop、spark、tez、leveldb、mongodb、mariadb、hive、hbase,還有oracle,都各自在自己不同的層面發力,大部分的這些都對java是極為友好的。
很多java程序員,都覺得搞.net開發的,就是拖拖控件而已,其實我可以告訴你,說出這種話的java程序員一般都還比較小白,如果你是搞.net的,你也可以說搞java的都是拷貝別人的開源軟件的代碼,然后改改而已。
當然改改沒什么問題,誰都不喜歡重復造輪子,比如,google里面也并非全部是創新,經常”拿“別人的東西自己改吧改吧,淘寶就很不用說了,招了一些能改c、會點編譯的程序員,經常拿各種開源框架開刀,然后表明是自己的東西。比如雙11的那個問題。
當然不是說淘寶找的人有問題,而是這個企業的文化就是銷售和廣告文化,后來的google也如此。
回到正題,wpf和silverlight(雖然已經EOL)中最大的創新莫過于xaml技術,如果你認為wpf只是winform的簡單升級,或者說你只會在wpf中拖控件,說明你還是一個非常初級的.net程序員,不管你工資上w沒有,或者你已經是項目經理了。
xaml天生就是為mvvm模型而生,這一點,搞前端的同學,應該熟悉,即使你不懂wpf,js和html怎么做mvvm,你也應該體會過它的好處。
wpf中在xaml中布局控件,并支持INotifyPropertyChanged接口,可以非常容易的實現界面和數據分離,做出一個mvvm模型出來。
說到標記性語言,我們看看jsp的jstl、struts2的tags,還有asp.net mvc3之后的razor引擎:
jstl和aspx的標簽類似,自由、強大,可以很容易的穿插交織到html標記中;
struts的標簽就是個另類,我個人反感這種既不遵循主流標準也不簡潔的東西,雖然好多人會說好用,那是個習慣問題,我這么說,不是說這東西難學難掌握,只是比較一下和razor引擎中的標簽語法,弱爆了。
razor,強大、簡潔、優雅。
你肯定覺得我是微軟.net的粉絲,其實我想告訴你的是,最強的標簽語言只有兩種,html和xml,穿插動態語句到服務端頁面上,然后刷出html,從來都不是好的做法,因為不只你一個人寫代碼,后面可能會有其他人維護這個頁面,本來這是需要由web designer來做的事情,但是有了語句,他的維護成本就很高。
規范的頁面開發,程序員是不會染指一個css、style的,動態語言在aspx、view、jsp上面應該盡量少用。否則你不如使用php和asp。
這一點,你會在工作中會深有體會的。
青春的你,怎么選擇?
看看現在的招聘吧,動不動就是
精通j2ee,精通struts、spring mvc、hibernate或者mybatis,對mysql、oracle有深入理解,精通webservice、精通多線程,能處理高并發,有的還得懂jvm,最好有hadoop等開發經驗。最后再來個211以上。
.net方面呢?
精通.Net,精通mvc3-5、精通wpf、wcf、多線程,mssql等等等等。
我現在處于離職狀態,所以每天收到獵聘上的一些推薦,都很郁悶,因為沒有一項是我精通的。
但是不妨礙我在2012年實習中,就拿到了13K的月薪,比一些正式員工可能還要高。
而且,仔細想想,代碼中經常講到要容易維護、這個設計模式、那個AOP,這個大并發,那個高性能,我個人沒有見到容易維護的代碼。學習一個新公司的一套模式,一套老產品,比學習一門新技術需要的時間長得多,你會發現,99%的情況下,你最需要的,不是什么代碼,模式,而是對產品的理解、對業務的理解,很多情況下,除非太菜太小白,大家的代碼都差不多,誰有時間重構代碼?程序員又為何加班?
這是行情,一個項目接一個項目,公司需要掙錢的,這是大部分公司的現狀。
為了回答java還是c#的問題,我會從我的經歷提供一些參考,既然是我的,那就不會是全面的和準確的,你自己判斷。
還是從故事開始吧!
在科大軟院(蘇州),因為老婆想和我一起在外面過個年,我不得不去臨時找實習,當時c和匯編不行啊,所以得選個流行的,什么流行呢,當時是web。
所以我遇到了java還是c#的問題,確切的是我遇到了j2ee還是.net的問題。
因為經常使用windows,又因為.net門檻如此低,所以毫不猶豫選擇了.net,當時是不會寫SQL的,但是卻系統學習了數據庫設計原理。
進入公司就接觸mvc3,覺得好,外企的技術確實比較新呢,比我學習.net時學的aspx優雅,那個時候開始接觸并嘗試理解mvc模式和ddd的概念。
當時,時薪25人民幣。
6個月的實習,基本能玩javascript和c#,然后sql還是不行,當時記得一個高級開發跟我說,他以前做delphi開發的時候,團隊寫sql寫的好就牛,我深以為然。
只會用Entityframework + mvc3 + javascript,開發網站的我,用理解很淺的.net的web技術體系,支撐了我和老婆在上海的生活費用,當時10年,我們租的拎包式入住公寓1500一個月,不算生活費、水電費。
再一次,通過一項技術,達到了我的目標,支撐了我的計劃,當時對技術的理解,但是偏執于.Net,對java陣營是不屑一顧的。
后來很快離開了科大軟院和蘇州,考取了中科院,到了北京,房租是1580一個月,照樣不算生活費、水電費。
沒辦法,學校發的補貼根本不夠押2付3的。
找實習,做過什么呢?office編程,而且當時的老板是從IBM下來的工程師,項目主要是java開發,jsf做頁面,招我過去,做word編程,還不能使用.net,你猜到了,我用的是vba。
沒做多久,公司發錢就開始拖延,兩周后,我沒有積蓄,只能被迫離職,后來加入一家公司,從4K到10k,用了8個月,在這里,我完善了程序員生涯中sql能力的快速成長,并且廣泛地使用了silvelight、aspx、oracle、mssql技術。記得當時一個北郵畢業的同事,做了6個月的office文檔在web展示,因為涉及到了com編程,所以運行非常不穩定也難于調試,更重要的是,拉一個頁面到展示,需要20秒。
老板是中科院軟件所的博士,架構很厲害,但對于這個技術細節并不擅長,問我有沒有辦法,我說做過vba,大概了解word的dom結構,我試試。那個同事說,如果你能做到穩定、快速的實現,你可以拿這個做你的畢業論文了。
我說,我試試。
臨危受命,我猥瑣地查找資料,研究百度文庫如何實現等等,后來為了.Net環境的一致性和可維護,所以拋棄了pdf + flash。
通過大量看老外的東西,我選擇了aspose.Net框架 + 一個能把word轉為Xaml的框架 + silverlight實現,可惜這兩個框架都收歐元,公司鐵定不會出錢,所以我猥瑣地對其進行了破解,也開始接觸IL碼。
docx文檔在線編輯 + 展示的功能完成,給老板run了一下,老板點了個贊,顯示時間縮短到5秒左右。
后來做了數據庫的靜態,顯示時間縮短為1秒內。老板又點了個贊。
后來帶領團隊,從mssql遷移代碼oracle,至今還記得和老板并肩一起寫存儲過程的情形,并感嘆微軟自身的數據庫外遷還得依靠三方工具的搞笑。
時光很快,當時回想,.Net是多么的強大,是么?
在工作的同時,學業,為了湊夠4個整天來實習,也為了自己的未來,我選擇了數據挖掘、計算機圖像處理、天文數據處理、文本檢索、分布式計算、高性能計算等所有聽起來很牛的東西。
不求甚解,一段一段的代碼和注釋,將能掌握的注入到自己的技術骨頭里去。
還記得在學校周一開組會,同一個組的基本都是博士了,我放棄碩博連讀,因為我實在年齡大了,得養家糊口。
后來一家西二旗的距離oracle很近的公司面上了,記得最后一輪面試是小屋子壓力面,從董事長到我的小組領導都在,沒有水。
首席架構師是科大少年班的,博士在網絡所讀的,問了一個問題:
你如何實現google的負載均衡?
那個問題我答的不好,其實即使不理解負載均衡的實現,也該從組成原理的總線仲裁知識中窺的一點參考。
所以那次又被鄙視了。但那次拿到了13K的月薪,當時的總監是漢王以前的副總裁,評價是,基礎扎實,思維靈活,實習階段就參與公司重大項目研發,值得培養。
直到現在,我,相信也還有很多程序員,遇到了數不清的技術,我經常會茫然,到底我該何去何從?
一些疑問:
訪問數據庫,隨便找個高效的connector或者driver就行了,一般提供數據的廠家,誰不提供connector?ORM是很必要,但是追求性能和反框架泛濫的公司不在乎ORM帶來的那點便利性,用一個jdbc + sql照樣寫穩定高效的數據訪問。
做web前端,真的需要自己寫一個框架出來?真正需要這種開發的項目有幾個呢?jQuery和d3,原生的javascript就夠了,你寫的也許不叫框架,最多就是個wrapper。
數據庫的唯一性索引、聚合索引、輔助索引都沒搞清楚,就開始搞hadoop、spark、hbase、mongodb,用人單位也一再這么要求的,你的項目中真的有那么大的數據量?在傳統的rdbms下解決不了?
你開始知道輪子的概念了,并且知道不要重復造輪子。可是你快不是程序員了,而是框架員了。
所以,回到java還是c#,這個問題,要比我遇到的技術分裂要簡單的多。
一些建議
我的意見是,忘記java或者c#的對立,如果要做一個開心、有自我追求、同時滿足就業的程序員,你需要重視以下方面:
函數調用棧,這個很多高級程序員只知其然不知其所以然。你可以不懂的匯編、函數入口、返回地址、寄存器,但你需要調試,你得深刻理解函數調用棧,無論是在dev模式調試struts開發的jsp頁面,還是debug模式調試aspx頁面,你得看懂調用棧的信息
基本的數據結構和算法,數據庫中索引的組織方式,是B+樹還是Hash,還是堆,你的公司有Web、桌面、移動用戶,有社區,有產品,你可能要做個推薦什么的,或者研究個社交圖譜什么的,這門技術可以幫助你。
一門動態語言。lua、python、javascript,都可以,你需要隨時和系統進行交互,或者實現一個原型,或者用程序的方式來畫點界面、數據圖什么,它們夠輕量、夠快捷。
一門重量級語言。比如java或者c#。你靠它們吃飯。
理解跨平臺的含義。掌握一些基本的跨平臺技術,比如xml、c、html、json。
重視網絡編程的練習和理解,在你使用URLConnection或者MySqlConnection或者WebRequest的時候,你是否理解它們的生命周期和底層實現,用什么語言無所謂,你要記住tcp/ip協議和http的基本特性。這樣不至于你寫了幾年程序,還不知道method=post是什么原理。
找一個順手的IDE,我個人不是CLI控,雖然不得不CLI,一個順手的IDE真的可以提高生產效率。搞.Net推薦vs + resharper,搞java推薦intellij IDEA.
關注一些熱門而經典的領域,比如機器學習、圖像處理、數據挖掘,即使已經有了mahout,不代表你不需要了解這些領域,你可能永遠不會在工作中使用它們,但它們的思想值得你擁有,因為你選擇了做程序員,而不是哪個公司的程序員。
剩下的,就是你的解決問題的思路和你實現的硬功夫(編碼能力),我相信,很多看這篇文章的人,不能夠輕易寫出一個ftp服務器,不能夠不參考、不聯網查詢資料寫出一個簡單的快速排序,也不能夠輕易寫出一段通用分頁SQL,但他們依然可以正常工作。
所以外面的功夫容易忘記,有網絡就能拾起,內功才是入骨的東西。
架構不是學出來的,是你的理解到位了,恰好工作中有這么個需求,你就開始整合你的已知,然后開始選擇輪子。
最重要的是,你千萬不要成為一個只會熟練使用框架的程序員,那樣,你會疲于奔命,你也許永遠只會使用hadoop,而寫不出一個hadoop,你只是一個hadoop程序員,而不是一個分布式程序員。
你也許永遠只會使用struts,而忘記了自己寫filter,你只是一個ssh程序員,而不是一個web工程師。
后記
人言三十而立,如今二十有九,反反復復,雖然買房買車(俗了~),依然一事無成。
結婚5年,老婆再次懷孕,她很興奮,我也很開心,由于時常加班,對她很抱歉。
目前離職,有些感觸,特撰此文。
-
JAVA
+關注
關注
19文章
2967瀏覽量
104729 -
程序員
+關注
關注
4文章
952瀏覽量
29799
發布評論請先 登錄
相關推薦
評論