.NET十年回顧
一、引子
從我還是編程菜鳥時起,.NET就從來沒讓我失望過。總是驚喜不斷。
當年我第一個項目是做個進銷存。用的Winform。當時我是機電工程師。編程只是業餘心血來潮而已。
.NET的低門檻、VS良好的編程體驗及MSDN完善的說明讓我從此踏上了碼農的不歸之路。
回首十年,是從.NET2.0一路走來,記得當年靈感之源發過一篇.NET技術堆棧大全,
(http://www.cnblogs.com/unruledboy/p/NetStack.html),對照下自己,4.5的很少用到,其他技術或多或少都有涉及。
二、.NET技術棧的分析
.NET從第一版發布至今,也有17年歷史了。能經久不衰,肯定有它的特長和亮點。我認為它最大的亮點就是生產力。最大的特長是做桌面應用。
說通俗點,就是.NET什麼都能做,做桌面他最精,出活他最快。
做移動端,.NET也有一席之地,xamarin和Unity。然而競爭對手有JAVA和Obj-C,Swift,H5與之PK。xamarin還嫩了點。
做後台服務,.NET Core,WCF這些技術不錯,但伺服器很多是Linux,JAVA先入為主,更有優勢。
做網頁,ASP.NET很好。但是競爭對手就更多更強了,JAVA,PHP,js,各種開源解決方案。
在現在流行的NO SQL、AI這些領域,.NET也有一席之地,然而這塊它顯然不是主流。
而在桌面這塊,有WPF,Winform,和他相關的有WCF,WF,ADO.NET,EF,LINQ。結合Visual Studio,Ofiice,SQL Server,競爭對手完全不是一個檔次。
那麼,這個技術棧最適合的領域是哪些呢,我認為就是運行在Windows系統上的各種程序。
桌面應用要資料庫有資料庫,要服務有服務,要控制項有控制項,要報表有報表(RDLC),簡直是要啥有啥。更不用說還有強大的第三方控制項、豐富的開源組件。
如果有人想用JAVA或者其他什麼技術做桌面,我只能說,這很奇葩。除非你對性能要求到苛刻程度。
如果你想做移動端,大數據,互聯網什麼的,繼續用.NET沒問題。但是性價比不突出。比如NO SQL這塊的,其他語言擅長就讓它做好了,.NET來調用就是。田忌賽馬,揚長避短。
有人說桌面藥丸,微軟要倒,What?微軟新CEO上台兩年股票漲了一倍多,現在活得好好的,DELPHI這個沒媽的孩子現在都在茁壯成長,是不是想多了。
又有人拿.NET的性能說事。說什麼不如C++云云。這個之前的老趙、xiaotie他們都分析過,按我經驗,還沒發現有什麼性能問題。
因為.NET類庫和C#語言都有一個特點,就是給你多種選擇。你想省事偷懶自然可以用現成的。想追求極致,甚至你可以用指針。我也用過指針。
差不了多少的性能,和天壤之別的開發效率,這個性價比應該仔細考量。
三、極限壓榨.NET技術棧的潛能
既然.NET最大亮點是生產力,就結合我個人的例子來說吧。
當初打算設計組態軟體。單位不是軟體公司,我的職責也不是設計組態軟體。一開始只是心血來潮。但是面臨一個很大問題。就是我看到的組態軟體,WINCC,Intouch,都是龐然大物。
如果不是腦子燒掉,不會想著靠一己之力做出來。但是我分析之後,發現我只需要解決兩個關鍵問題。一個是組態設計器,一個是網關。
網關我參考的是OPC規範。按下不表。組態設計器這個,因為我看上了WPF對圖元的表現能力、Blend的零代碼設計能力。先在網上搜WPF圖形設計器,找到了這個:
感謝周金根提供的這個線索。找到了一套WPF開源的圖形設計組件: Diagarm Designer。
然而看了代碼體驗了DEMO之後,再比較WINCC等的功能,感覺工作量還是十分巨大。
這時候我想,如果能把這套組件的界面連線功能納入Visual Studio就好了。於是繼續搜索,發現了這個:
https://msdn.microsoft.com/zh-cn/subscriptions/bb546938(v=vs.90).aspx
果然微軟沒有讓我失望。於是我只需要專註於如何將我需要的組態設計器功能嵌入到Visual Studio神器就可以。
.NET對資料庫、文件IO、通訊協議的完美支持讓我編程省了很多事。加上我之前積累的類庫,進展飛快。
這時候碰到一個新問題,就是常規組態軟體有一個重要功能:組態變數。也就比如1號電機、2號電機同時運行的話顯示綠色,應該表示為:Motor1.Running & Motor2.Running。
這要求我的設計器能夠支持常規的四則運算、邏輯運算,也就是支持複雜的表達式。
微軟的表達式樹ExpressionTree 提供了對表達式完美的封裝。我可以方便的利用它實現我的語法。
我的業餘愛好是研究程序化交易。我選擇了Winform,繪製K線圖我只用了幾百行代碼,就實現了一個可以縮放、拉伸、移動、加入自定義指標的K線圖。
為什麼這裡選用Winform而非WPF?因為WPF優勢是界面與代碼分離,利用Blend工具人工繪圖,冗餘較多。但做K線圖需要讀入大量數據,程序生成,使用Winform提供的GDI+ API繪製效率更高。
我利用組態項目的表達式解析器加以改進,很快做出來股票預警器。其他地方也很多參考、借鑒了網關、組態設計器的現成代碼和思路。
現在做成的這個交易系統,包括圖形界面、自定義指標、各種函數支持、策略生成器、回測、實盤運行,總共代碼也沒有多少,非常簡潔。這要感謝.NET強大的架構能力和類庫。
很多人說python做程序化交易首選,比如python的腳本能力和各種圖表繪製能力。但我大C#的強類型編程能力、架構能力、各種語法糖,寫策略不是python能比的。至於自定義圖表,別忘了可以導入或者嵌入EXCEL。
一旦你用慣了.NET,有了自己積累的類庫,和長期培養的架構理念、抽象能力。你可以在桌面上實現你能想像到的大部分事,讓程序成為你的好幫手。
有人說.NET 不能做大數據、不能玩阿爾法狗什麼的。拜託。這些東西本來就不是個人、小團隊玩的,是國家或者大集團才用得上的。別想多了。
作為一個.NET鐵杆粉絲,我只感到慶幸。因為.NET很適合我和我的行業。兩岸猿聲啼不住,輕舟已過萬重山。
github地址:https://github.com/GavinYellow/SharpSCADA。我的第一個開源項目。為了推廣它,我這國慶節每天抽出點時間敲鍵盤。歡迎大家多提寶貴意見和建議。
※Docker入門之四搭建私有倉庫
※用 Python 擼一個區塊鏈
※簡單說明CGI是什麼
※「充分利用你的Azure」將Azure用作雲計算平台
※Apache虛擬主機配置
TAG:IT優就業 |