CLR VB.NET學習經驗
VB.NET還是比較常用的,于是我研究了一下CLR VB.NET,在這里拿出來和大家分享一下,希望對大家有用。
迄今為止,業界對VB.NET討論得最多的特色或許就是CLR VB.NET運行在CLR之上,正是CLR VB.NET帶來了許多關鍵的新特色(包括缺點在內)。例如,CLR使得VB.NET支持跨語言的繼承以及自由線程。
在VB6 中,分布式VB程序要求有VB運行時庫msvbvm60.dll支持,即該運行時庫必須隨同應用一起分發。其他許多語言,比如C++ 和Java,也有類似的要求。
在.NET中,所有Visual Studio 語言共享同樣的運行時環境CLR.改用CLR帶來了幾個重要的結果:現在所有Visual Studio 語言都共用同樣的IDE 、同樣的窗體引擎、同樣的異常處理機制,等等。它意味著VBc在很大程度上已經可以和.NET的其他語言相提并論,如C#等。然而,對于CLR 的異議仍舊存在,VB業界仍在激勵地爭辯它地價值。
不管應用是用VB、C#還是其他.NET語言編寫,所有VS.NET代碼都是編譯成中間語言(Intermediate Language ,IL)。當應用運行時,一個實時編譯器(just-in-time compiler ,或稱為JIT )就把IL代碼編譯成機器語言。在理論上,它意味著為非Windows 的平臺構造.NET運行環境是可能的,但目前還沒有出現有關這類系統的正式消息。IL有一個缺點:正如VB在5.0 以前的版本,IL代碼對于類似的反向編譯工程很敏感。由于存在這種可能性,許多開發者對于.NET框架的整體安全性抱有懷疑。
對CLR 進行優化影響IL層次上的代碼,它使得所有使用CLR 的語言受益。然而,對于特定語言的優化涉及到如何把代碼編譯成IL代碼,它根據特定語言的語法進行。因此,.NET各種語言之間存在一定的性能差異是必然的。但不管如何,從整體上來看這仍舊是好事,例如CLR 為VB帶來了和C#一樣的調試和分析工具——之所以能夠如此,是因為它們都使用一樣的工具。
CLR 提供了前所未有的跨語言集成能力,其中包括跨語言繼承代碼的能力。
所有使用CLR 的語言都使用一個公共類型系統(Common Type System),它使得開發那些運用多種語言的應用變得更為容易。
在CLR 之內運行的代碼稱為“受管理的代碼”(Managed Code),受管理代碼所使用的內存由CLR 全面控制。受管理的代碼有著許多優點,包括交叉語言集成、跨語言異常控制以及一個組件交互的簡化模型。VB.NET只能以受管理代碼方式運行,與此相對應,C#卻具有將代碼轉入非受管理方式運行的能力(運行在CLR 之外),比如執行指針處理之類的操作。這是VB.NET不能與C#相提并論的地方之一。然而,這種能力的是否重要,對于不同的人、不同的用途來說都有所不同。
由CLR 導致的體系上的不同不僅僅是跨語言繼承、共享功能和受管理代碼,它還有更深刻的意義。VB.NET 的底層體系不再是COM ;另外,VB.NET中所有東西都是對象,甚至連字符串也一樣。由于這些原因以及其他許多原因,Microsoft 改變了底層體系管理對象的方法。COM 系統通過引用計數方式管理對象,每當對象被引用時,引用計數就增加。當對象引用超出作用范圍或者被釋放時,計數器的值就減少;一旦引用計數為0 ,對象就被釋放。Microsoft 聲稱。
NET 體系中的引用計數開銷實在太大,使得.NET采用引用計數不再合適,因此它就放棄了引用計數,改用垃圾回收(Garbage Collection)。以上介紹CLR VB.NET。
【編輯推薦】