UI设计 薇晓朵数字商城

 找回密碼
 加入我們

軟件編程開發程序員老壞貓分享:從組態軟件股票預警器回顧.NET十年

[複製鏈接]
小豬哼囔 發表於 2019-1-15 17:43:04 | 顯示全部樓層 |閱讀模式
文章轉自網絡


一、   引子

從我還是編程菜鳥時起,.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,Office,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很適合我和我的行業。兩岸猿聲啼不住,輕舟已過萬重山。

本來相關分類: 開源純C#工控網關+組態軟件
相關標籤: C#, .NET 技術堆棧
回復

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 加入我們

本版積分規則

备案权重域名预定

點基跨境

GMT+8, 2025-1-23 03:13

By DZ X3.5

QQ

快速回復 返回頂部 返回列表