人人做人人澡人人爽欧美,国产主播一区二区,久久久精品五月天,羞羞视频在线观看免费

當前位置:蘿卜系統下載站 > 技術開發教程 > 詳細頁面

COM, COM+ and .NET 的區別(轉)

COM, COM+ and .NET 的區別(轉)

更新時間:2022-06-30 文章作者:未知 信息來源:網絡 閱讀次數:

作者:Sunwen譯

所有的優秀程序員都會盡自己的最大努力去使自己所寫的程序具有更好的可重用性,因為它可以讓你快速地寫出更加健壯和可升級性的程序。

有兩種使代碼重用的選擇:
1. 白盒:最簡單的一種,就是把你的程序片拷貝到另一個文件中。
2. 黑盒:它包括把編譯過的程序片連接起來。因此客戶端可以調用的編譯過的黑盒類庫就叫作組件。

.Net中也同樣為開發者提供了類似于COM的建立和展開組件的方法。開發人員很容易地被這兩種以組件為基礎的開發模型所迷惑,所以,讓我們來看一看這些不同的開發方法,以使我們消除疑惑。

COM的產生

在以前程序設計過程中,程序員把它們的函數庫放在一個叫做目標(Object)文件的單獨文件中,在這些文件中,包含了編譯過的代碼。當程序員要使用一個特別的目標文件的時候,他們把客戶程序編譯成機器代碼,然后依靠動態鏈接的手段把客戶程序聯接到目標文件上,最后變成一個單一的可執行文件。這種作法的唯一的好處在于它節省了編譯函數庫的時間。但是它有許多的缺點,比如由于在每個單獨的可執行文件中都有一個程序庫包括在里面,浪費了許多存儲空間;對應用程序的維護也是非常困難的,如果在函數庫中發現了一個bug,整個可執行文件都要被重新編譯和分發。

還有不只一個的嚴重的限制在里頭,一個客戶應用程序必須要和用同一種語言編制的函數庫在一起才能使用。比如說,一個用QuickBasic寫的客戶應用程序就不能引用一個用C++寫的函數庫。

因此,微軟公司出品了COM,COM僅僅只是一個規范。不管組件用什么語言寫成,只要符合這個COM規范,就能被用任何一種語言寫成的客戶程序調用。此外,程序員不必再擔心要去建立一個單一的可執行文件,因為組件是以GUID(Global Unique Identifier全球唯一標識符)來標識的。GUID是一個128位的號碼,和一些相關的信息一起被放在系統的注冊表中,用來唯一標識組件。客戶應用程序只在運行期間才動態地建立一個組件的實例,并使用這個組件的功能,因此,只需要一個函數庫的拷貝。它的缺點就是大家常常提到?quot;DLL地獄"。這個問題在一個DLL要被一個新版本的DLL所取代時引發。開發者不得不通過關閉所有的客戶應用程序的方法(如果不行,還要關閉WWW服務)來達到清除所用對這個組件的引用的目的。有時所有的方法都還起不了作用,那你只好重新啟動服務器后才能替換掉老的DLL。

COM+

為了讓企業級的應用程序能使用上COM,它必需要有以下的特定的能力。
· 驗證能力
· 對象池(Object Pooling)
· 事務處理
· 支持分布式架構
為了使開發者不必去為他們的組件添加這些能力,微軟公司出品了DCOM(Distributed COM分布式COM)和MTS(Microsoft Transaction Server微軟事務服務器)。使用這兩種技術,開發者就可以把精力用在他們的商業邏輯上,而不必放在后臺的他們的組件上。

DCOM是一個用于分布式的組件之間的通訊的RPC(Remote Procedure Call)協議。客戶端向一個本地機的代理類發送請求,然后由代理類將這個請求隱含地給安裝在遠程機器上的"根"類,然后執行結果原路送回給代理類,最后代理類把它們回送給客戶端。因此,客戶程序的位置完全與組件的位置無關。DCOM的缺點在于,由于DCOM使用的是一個獨立的硬件端口,而不是HTTP協議的80端口,所以在組件間通訊的過程中,必須保證這個端口是開著的。這是一個嚴重的安全問題。所以DCOM不能夠輕易地穿越防火墻。

為了使用MTS,程序員在它們的組件里放置特別的MTS鉤子,編譯后把他們放在MTS包中。把有關系的組件放在一個單一的包中有它自己的好處。當客戶請求一個包中的一個組件的一個實例的時候,MTS確保為這個包建立一個新的專門的線程,一個新的組件實例被建立在這個線程上并被應用事務服務。至于對象池服務和安全服務是否要被建立,那就要看開發者的請求了。

MTS允許相關的作業單元被當作一個事務來對待,這意味著如果所有的作業單元被成功地完成,整個事務就被當作成功地完成,反之如果有一個單元未成功完成,整個事務將被重新輪回。

在客戶請求對象和釋放對象后,MTS仍保存著這個對象,所以當另一個客戶請求同一個組件的時候,MTS就將保存著的對象交給它。通過這種方式,MTS減少了在服務器源實例化的次數。

MTS允許開發者用安全措施來組裝他們的組件,以使其具有識別請求它的服務的客戶的能力。這能夠確保未經授權的客戶不能夠使用組件的功能。

MTS以COM+的名義被完整地整合到了微軟公司的Windows 2000操作系統中,但是COM+不僅僅只有MTS,它還包括一些其它的服務。MSMQ(Microsoft Message Queue Server),一個與MTS一同發布的服務,也被以COM+的名義整合到了Windows 2000中。MSMQ允許服務器端和客戶端進行同步的通訊。事件服務(Event Service)也被加了進來,它使服務器能夠與客戶端同步地交流事件的發生。負載平衡服務(Load Balancing)自動地實例化機器上的具有最多資源的服務器上的請求對象。

.NET

.Net提供了一種全新的建立和展開組件的方法。它就是大名鼎鼎的Assemblies。使用COM,開發者必需要在服務器上注冊組件,這也就是說,系統注冊表中的組件的信息必須被更新。這樣做的目的是保證組件的中心位置,以使COM+能夠找到合適的組件。使用.Net的Assemblies,裝配(Assembly)文件把所有需要的元數據(meta data)都壓入一個叫Manifests(名單)的一個特殊的段中。在.Net中,要使assembly對用戶有效,只要簡單地把他們放在一個目錄中就行了。當客戶程序請求一個特別的組件的實例的時候,.Net運行期(runtime)在同一個目錄搜尋assembly,在找到后,分析其中的manifest,以取得這個組件所提供的類的信息。由于組件的信息是放在manifest里的,所以開發者就沒有必要把組件注冊到服務器上,因此,就可以允許幾個相同的組件安全地共存在一個相同的機器上了。

建立一個.Net assembly并不像建立一個VB6組件,唯一讓開發者操心的就是商業邏輯,所有的后臺代碼全部由.Net運行期產生,而且由于.NET運行期具有碎片收集器的功能,組件不必擔心它的引用數目(在COM中是靠Iunknown的幫助)。簡單地說,在.NET中建立一個assembly比建立一個VB6 COM要簡單地多。

純的.NET assemblies不能夠在COM+服務下注冊,因為它們是和COM不同的二進制標準。面對.NET,assemblies的前景相對于COM來說是"高級的COM"。但是由于當前架構于COM+上的應用程序的可靠性,COM還會持續一段時間。這也許就是微軟公司向開發者同時提供開發.NET assemblies和COM的工具的原因吧。

類型庫引入器(Type Library Importer (TLBIMP.exe))工具可以把COM組件封裝成.NET,以使以前的東西可以在.NET應用程序中繼續使用。

類型庫導出器(Type Library Exporter (TLBEXP.exe))工具將.NET組件封裝成COM,這個工具也是很有用的,如果你要用你的.NET assemblies去替換原有的COM組件,就得用到它了。由COM+提供的服務不能被忽略,所以把.NET assemblies封裝成COM組件就變得相當重要了。作為一種選擇,開發者可以從.NET基礎類庫中選擇更多

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

網站地圖xml | 網站地圖html
主站蜘蛛池模板: 临安市| 衢州市| 类乌齐县| 平阳县| 石渠县| 崇礼县| 巢湖市| 衡阳县| 喜德县| 金坛市| 马关县| 咸宁市| 永定县| 灌云县| 济宁市| 融水| 伊宁市| 监利县| 尖扎县| 彭泽县| 临夏县| 封丘县| 贵德县| 牙克石市| 神木县| 京山县| 林周县| 夹江县| 呼图壁县| 郑州市| 常德市| 长顺县| 卢龙县| 化隆| 射阳县| 合作市| 浠水县| 安庆市| 桦甸市| 武威市| 亚东县|