導航:首頁 > 編程語言 > ccom編程

ccom編程

發布時間:2024-10-14 15:08:46

A. COM編程和API編程有什麼區別

COM是Windows非常非常重要的部分.

OLE DB是COM, ADO是COM,
OFFICE是COM;
Windows Media Player是COM
WMI是COM
IE 是COM
數不勝數

有了COM知識, 你既能用這些個東西, 也能寫類似的東西給別人用.

B. com編程是什麼意思啊

COM(Component Object Model)是一種面向對象的組件技術,旨在實現各種軟體之間的互操作性。COM編程是指利用COM技術來進行編程,其中包括使用COM對象庫、創建COM組件等操作。通過COM編程,我們可以實現多種應用程序之間的無縫集成,提高軟體的靈活性和可擴展性。
COM編程在很多領域都有廣泛的應用。在Windows系統中,COM組件是實現許多重要功能的關鍵技術之一。例如,我們可以編寫一個COM組件來實現文件的讀寫、網路通信或其他系統功能,並在多個應用程序中重復利用。此外,在開發瀏覽器插件、ActiveX控制項等方面,COM編程也發揮著重要的作用。
COM編程雖然具有許多優點,但其學習曲線較為陡峭。對於初學者來說,我們建議先了解面向對象編程的基本概念,再深入了解COM的技術原理和實現方式。此外,相關的編程知識和經驗也非常重要。可以通過閱讀相關書籍、參加培訓課程、參與開源項目等方式,提高自己的技能水平。最重要的是,需要不斷地動手實踐,積累實際經驗,才能真正掌握COM編程的奧義。

C. c#編程,添加引用時,COM和.NET有什麼區別代表什麼意思

COM是windows的com組件,沒有.NET的時候有段時間都是基於com的編程,在windows系統中還在使用。.NET其實是微軟在2002年推出的替代COM的編程平台。因為據一些老程序員說COM編程太惡心了,微軟估計也覺得讓大家繼續使用太難受了,就發明了.NET。

D. com編程的COM編程入門

第一部分——什麼是COM,如何使用COM。
本文的目的是為剛剛接觸COM的程序員提供編程指南,並幫助他們理解COM的基本概念。內容包括COM規范簡介,重要的COM術語以及如何重用現有的COM組件。本文不包括如何編寫自己的COM對象和介面。
本文由淺入深描述COM的內在運行機制,教你如何使用第三方提供的COM對象(以Windows 外殼組件Shell為例)。讀完本文後,你就能掌握如何使用Windows操作系統中內建的組件和第三方提供的COM對象。
本文假設你精通C++語言。在例子代碼中使用了一點MFC和ATL,如果你不熟悉MFC和ATL也沒關系,本文會對這些代碼進行完全透徹的解釋。本文包括以下幾個部分:
簡單地說,COM是一種跨應用和語言共享二進制代碼的方法。與C++不同,它提倡源代碼重用。ATL便是一個很好的例證。源碼級重用雖然好,但只能用於C++。它還帶來了名字沖突的可能性,更不用說不斷拷貝重用代碼而導致工程膨脹和臃腫。
Windows使用DLLs在二進制級共享代碼。這也是Windows程序運行的關鍵——重用kernel32.dll, user32.dll等。但DLLs是針對C介面而寫的,它們只能被C或理解C調用規范的語言使用。由編程語言來負責實現共享代碼,而不是由DLLs本身。這樣的話DLLs的使用受到限制。
MFC引入了另外一種MFC擴展DLLs二進制共享機制。但它的使用仍受限制——只能在MFC程序中使用。
COM通過定義二進制標准解決了這些問題,即COM明確指出二進制模塊(DLLs和EXEs)必須被編譯成與指定的結構匹配。這個標准也確切規定了在內存中如何組織COM對象。COM定義的二進制標准還必須獨立於任何編程語言(如C++中的命名修飾)。一旦滿足了這些條件,就可以輕松地從任何編程語言中存取這些模塊。由編譯器負責所產生的二進制代碼與標准兼容。這樣使後來的人就能更容易地使用這些二進制代碼。
在內存中,COM對象的這種標准形式在C++虛函數中偶爾用到,所以這就是為什麼許多COM代碼使用C++的原因。但是記住,編寫模塊所用的語言是無關的,因為結果二進制代碼為所有語言可用。
此外,COM不是Win32特有的。從理論上講,它可以被移植到Unix或其它操作系統。但是我好像還從來沒有在Windows以外的地方聽說過COM。

E. 請問com編程 .net編程有什麼區別啊

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

有兩種使代碼重用的選擇:

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 Procere 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基礎類庫中選擇更多的功能。

閱讀全文

與ccom編程相關的資料

熱點內容
干程序員可以干兼職嗎 瀏覽:640
go中文pdf 瀏覽:530
電腦dns的伺服器地址設置 瀏覽:530
編程出1000以內水仙花數 瀏覽:113
程序員多大轉行 瀏覽:879
單片機燈 瀏覽:871
如何啟動u8管理伺服器 瀏覽:280
程序員消費多少 瀏覽:510
編譯室半年總結怎麼寫範文 瀏覽:469
windowsapi編程入門教程 瀏覽:837
單片機51系列 瀏覽:58
python迭代器是什麼 瀏覽:538
bat備份文件夾刪除 瀏覽:928
推拉的文件夾 瀏覽:517
嵌入式linux前景 瀏覽:13
屏幕滾動命令 瀏覽:504
解壓珠含毒素 瀏覽:770
美文誦讀配樂用什麼app 瀏覽:569
java代碼設置字體 瀏覽:450
linuxsamba重啟命令 瀏覽:825