青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-48  評(píng)論-259  文章-1  trackbacks-0

面向?qū)ο蟮乃枷腚y以適應(yīng)這種分布式軟件模型,于是組件化程序設(shè)計(jì)思想得到了迅速的發(fā)展。

按照組件化的程序設(shè)計(jì)的思想,復(fù)雜的應(yīng)用程序被設(shè)計(jì)成一些小的,功能單一的組件模塊,這些組件模塊可以運(yùn)行在同一臺(tái)機(jī)器上,也可以運(yùn)行在不同的機(jī)器上。

為了實(shí)現(xiàn)這樣的應(yīng)用軟件,組建程序和組建程序之間需要一些極為細(xì)致的規(guī)范, 只有組件程序遵守了這些共同的規(guī)范,然間系統(tǒng)才能正常運(yùn)行。

為此,OMG和Microsoft分別提出了CORBA(Common Object Request Breaker Architecture)和COM(Component Object model)標(biāo)準(zhǔn),目前CORBA模型主要應(yīng)用于UNIX操作系統(tǒng)平臺(tái)上,而COM 則主要應(yīng)用于Microsoft Windows操作系統(tǒng)平臺(tái)上。


在COM標(biāo)準(zhǔn)中,一個(gè)組件程序也被稱為一個(gè)模塊,它可以是一個(gè)動(dòng)態(tài)連接庫(kù)(DLL), 被稱為進(jìn)程內(nèi)組件(in-of-process component)也可以是一個(gè)可執(zhí)行程序(EXE),被稱為進(jìn)程外組件(out-of-process component).


COM對(duì)象是建立在二進(jìn)制可執(zhí)行代碼級(jí)的基礎(chǔ)上,而C++等語(yǔ)言中的對(duì)象是建立在源代碼級(jí)基礎(chǔ)上的,因此COM對(duì)象是語(yǔ)言無(wú)關(guān)的。這一特性使用不同編程語(yǔ)言開發(fā)的組件對(duì)象進(jìn)行交互成為可能。

在Microsoft Windows系統(tǒng)平臺(tái)上,COM技術(shù)被應(yīng)用于系統(tǒng)的各個(gè)層次,從底層的COM對(duì)象管理到上層的應(yīng)用程序交互都用到了COM標(biāo)準(zhǔn)。


概述

COM既提出了組件之間進(jìn)行交互的規(guī)范,也提供了實(shí)現(xiàn)交互的環(huán)境, 因?yàn)榻M件對(duì)象之間交互的規(guī)范不依賴于任何特定的語(yǔ)言,所以COM也可以是不同語(yǔ)言協(xié)作開發(fā)的一種標(biāo)準(zhǔn)。


OLE技術(shù)以COM規(guī)范為基礎(chǔ),OLE充分發(fā)揮了COM標(biāo)準(zhǔn)的優(yōu)勢(shì),使Windows操作系統(tǒng)上的應(yīng)用程序具有極強(qiáng)的可交互性。如果沒(méi)有OLE的支持,Windows操作系統(tǒng)則會(huì)遜色很多。


但是,COM規(guī)范并不局限于OLE技術(shù),實(shí)際上,OLE技術(shù)只是COM的一個(gè)應(yīng)用而已,這幾年,OLE技術(shù)在進(jìn)行網(wǎng)絡(luò)互連是顯示出了很大的局限性,而COM則表現(xiàn)出了極強(qiáng)的適應(yīng)能力。


COM標(biāo)準(zhǔn)包括規(guī)范和實(shí)現(xiàn)兩大部分,規(guī)范部分定義了組件和組件之間通信的機(jī)制,這些規(guī)范不依賴于任何特定的語(yǔ)言和操作系統(tǒng),只要按照該規(guī)范,任何語(yǔ)言都可以使用; COM標(biāo)準(zhǔn)的實(shí)現(xiàn)部分是COM庫(kù),COM庫(kù)為COM規(guī)范的具體實(shí)現(xiàn)提供了一些核心服務(wù)。


COM是面對(duì)對(duì)象的軟件模型,因而對(duì)象是他的基本要素之一。類似于C++中對(duì)象的概念,對(duì)象是某個(gè)類(class)的一個(gè)實(shí)例;而類則是一組相關(guān)的數(shù)據(jù)和功能組和在一起的一個(gè)定義。使用對(duì)象的應(yīng)用(或另一個(gè)對(duì)象)成為客戶,有時(shí)也成為對(duì)象的用戶。


接口是一組邏輯上相關(guān)的函數(shù)集合,其函數(shù)也被稱為接口成員函數(shù)。對(duì)象通過(guò)接口成員函數(shù)為客戶提供各種形式的服務(wù)。


在COM模型中,對(duì)象本身對(duì)于客戶來(lái)說(shuō)是不可見(jiàn)的,客戶請(qǐng)求服務(wù)時(shí),只能通過(guò)接口進(jìn)行。每一個(gè)接口都由一個(gè)128位的全局唯一標(biāo)識(shí)符(GUID,Globally Unique Identifier)來(lái)標(biāo)識(shí)。客戶通過(guò)GUID獲得接口的指針,在通過(guò)接口指針,客戶就可以調(diào)用其相應(yīng)的成員函數(shù)。


一般來(lái)說(shuō),接口是不變的,只要客戶期望的接口在組建對(duì)象中還存在,它就可以繼續(xù)使用該接口所提供的服務(wù)。對(duì)象可以支持多個(gè)接口,因此對(duì)組件對(duì)象的升級(jí)可通過(guò)增加接口的辦法實(shí)現(xiàn),這樣得到的新接口可以不影響老接口的使用。


客戶如何來(lái)標(biāo)識(shí)COM對(duì)象呢?與接口類似,每個(gè)對(duì)象也用一個(gè)128位GUID來(lái)標(biāo)識(shí),稱為CLSID(class identifier,類標(biāo)識(shí)符或類ID),用CLSID標(biāo)識(shí)對(duì)象可以保證(概率意義上)在全球范圍內(nèi)的唯一性。


只要系統(tǒng)中含有這類COM對(duì)象的信息,并包括COM對(duì)象所在的模塊文件(DLL或EXE文件)以及COM對(duì)象在代碼中的入口點(diǎn),客戶程序就可以由此CLSID來(lái)創(chuàng)建COM對(duì)象。


那么客戶怎么使用COM對(duì)象所提供的服務(wù)呢?客戶獲得的又是什么呢?

實(shí)際上,客戶成功創(chuàng)建對(duì)象后,它得到的是一個(gè)指向?qū)ο竽硞€(gè)接口的指針,因?yàn)镃OM對(duì)象至少實(shí)現(xiàn)一個(gè)接口,所以客戶就可以調(diào)用該接口提供的所有服務(wù)。


但是COM對(duì)象可以有自己的狀態(tài),正是這種狀態(tài)才使客戶感覺(jué)到COM對(duì)象的存在。如果客戶同時(shí)擁有兩個(gè)相同CLSID的對(duì)象,則兩個(gè)對(duì)象可以有不同的狀態(tài),客戶完全不必關(guān)心COM對(duì)象是怎么實(shí)現(xiàn)的,以及兩個(gè)對(duì)象的狀態(tài)數(shù)據(jù)之間有什么關(guān)系(數(shù)組或者鏈表)。當(dāng)然,COM對(duì)象也可以是無(wú)狀態(tài)的,這種COM對(duì)象以提供功能服務(wù)為主,可以用來(lái)代替?zhèn)鹘y(tǒng)的API函數(shù)接口,使得應(yīng)用程序編程接口更為有序,組織層次性更強(qiáng)。


COM本身除了規(guī)范之外,也有實(shí)現(xiàn)的部分,其中包括一些核心的系統(tǒng)級(jí)代碼,也正是這部分核心代碼,才使得對(duì)象和客戶之間可通過(guò)接口在二進(jìn)制代碼級(jí)進(jìn)行交互 。

在Microsoft Windows操作系統(tǒng)環(huán)境下,這些庫(kù)以.dll文件的形勢(shì)存在,其中包括以下內(nèi)容:

(1) 提供了少量的API函數(shù)實(shí)現(xiàn)客戶和服務(wù)端COM應(yīng)用的創(chuàng)建過(guò)程。在客戶端,主要是一些創(chuàng)建函數(shù);而在服務(wù)器端,提供一些對(duì)象的訪問(wèn)支持。

(2) COM通過(guò)注冊(cè)表查找本地服務(wù)器即EXE程序,以及程序名與CLSID的轉(zhuǎn)換等。

(3) 提供了一些標(biāo)準(zhǔn)的內(nèi)存控制方法,使應(yīng)用控制進(jìn)程中內(nèi)存的分配。

COM庫(kù)一般不在應(yīng)用程序?qū)訉?shí)現(xiàn),而在操作系統(tǒng)層次上實(shí)現(xiàn),因此一個(gè)操作系統(tǒng)只有一個(gè)COM庫(kù)實(shí)現(xiàn)。而且COM庫(kù)的實(shí)現(xiàn)必須依賴于具體的系統(tǒng)平臺(tái),尤其是系統(tǒng)底層的一些標(biāo)準(zhǔn)。

COM庫(kù)可以保證所有的組件按照統(tǒng)一的方式進(jìn)行交互操作,而且它使我們?cè)诰帉慍OM應(yīng)用時(shí),可以不用編寫為進(jìn)行COM通信而必需的大量基礎(chǔ)代碼,而是直接利用COM庫(kù)提供的API進(jìn)行編程,從而大大加快了開發(fā)的速度。例如,現(xiàn)在COM庫(kù)的版本都支持遠(yuǎn)程組件即分布式COM,我們不用編寫任何網(wǎng)絡(luò)或者RPC(remote procedure call)的代碼,就可以實(shí)現(xiàn)在網(wǎng)絡(luò)上進(jìn)行程序之間的通信。


如果我們用面向?qū)ο笳Z(yǔ)言來(lái)實(shí)現(xiàn)COM對(duì)象,則很自然可以用類類定義對(duì)象。在C語(yǔ)言中,對(duì)象的概念可能變成一個(gè)邏輯概念,如果兩個(gè)對(duì)象同時(shí)存在,則在接口實(shí)現(xiàn)中必須明確知道所進(jìn)行的操作是針對(duì)哪個(gè)對(duì)象的,這個(gè)過(guò)程可由COM接口的定義保證。


COM規(guī)范使用GUID來(lái)標(biāo)識(shí)COM對(duì)象的思想源于OSF(Open Software Foundation)采用的UUID(Universallz Unique Identifier), UUID被定義為DCE(Distributed Computing Environment)的一部分,主要用于表識(shí)RPC通信的雙方。


除了封裝性和重用性,C++對(duì)象還有一個(gè)重要特性是多態(tài)性。正是C++對(duì)象的多態(tài)性,才體現(xiàn)了C++語(yǔ)言用類描述事物的高度抽象的特征;COM對(duì)象也 具有多態(tài)性,但這種多態(tài)性需要通過(guò)COM對(duì)象所具有的接口才能體現(xiàn)出來(lái),就像C++對(duì)象的多態(tài)性需要通過(guò)其(virtual)函數(shù)才能體現(xiàn)一樣。


從API到COM接口

假如我們要實(shí)現(xiàn)一個(gè)字處理應(yīng)用系統(tǒng),它需要一個(gè)查字典的功能,按照組件化程序設(shè)計(jì)的方法,自然應(yīng)該把查字典的功能放到一個(gè)組件(.dll)程序中實(shí)現(xiàn)。如果以后字典程序的查找算法或者字典庫(kù)改變了,只要應(yīng)用程序和組件之間的接口不變,則新的組件程序仍然可以被應(yīng)用系統(tǒng)使用。這就是采用組件程序帶來(lái)的靈活性。


為了把應(yīng)用系統(tǒng)和組件程序連接起來(lái),又能使它們協(xié)同工作,最簡(jiǎn)單的做法就是先定義一組查字典的函數(shù),而且這組函數(shù)盡可能一般化,不要加入特定的與字典庫(kù)相關(guān)的知識(shí)。


函數(shù)
 功能說(shuō)明
 
Initialize
 初始化
 
LoadLibrary
 裝入字典庫(kù)
 
InsertWord
 插入一個(gè)單詞
 
DeleteWord
 刪除一個(gè)單詞
 
LookupWord
 查找單詞
 
RestoreLibrary
 把內(nèi)存中的字典庫(kù)存入指定的文件中
 
FreeLibrary
 釋放字典庫(kù)
 

平面型的API接口層可以很好地把兩個(gè)程序連接起來(lái),但存在以下一些問(wèn)題:

(1) 當(dāng)API函數(shù)非常多時(shí),使用會(huì)非常不方便,需要對(duì)函數(shù)進(jìn)行組織。

(2) API函數(shù)需要標(biāo)準(zhǔn)化,按照統(tǒng)一的調(diào)用方式進(jìn)行處理,以適應(yīng)不同的語(yǔ)言編程實(shí)現(xiàn)。參數(shù)的傳遞順序,參數(shù)類型,寒暑返回處理都需要標(biāo)準(zhǔn)化。

COM定義了一套完整的接口規(guī)范,不僅可以彌補(bǔ)以上API作為組件借口的不足,還充分發(fā)揮了組件對(duì)象的優(yōu)勢(shì),并實(shí)現(xiàn)了組件對(duì)象的多態(tài)性。

接口定義和標(biāo)識(shí)
從技術(shù)上講,接口是包含了一組函數(shù)的數(shù)據(jù)結(jié)構(gòu),通過(guò)這組數(shù)據(jù)結(jié)構(gòu),客戶代碼可以調(diào)用組件對(duì)象的功能。接口定義了一組成員函數(shù),這組成員函數(shù)是組件對(duì)象暴露出來(lái)的所有信息,客戶程序利用這些函數(shù)或的組件對(duì)象的服務(wù)。


客戶程序用一個(gè)指向接口數(shù)據(jù)機(jī)構(gòu)的指針來(lái)調(diào)用接口成員函數(shù)。接口指針實(shí)際上又指向另一個(gè)指針,這第二個(gè)指針指向一組函數(shù),稱為接口函數(shù)表(虛函數(shù)表),接口函數(shù)表中每一項(xiàng)為4個(gè)字節(jié)長(zhǎng)的函數(shù)指針,每個(gè)函數(shù)指針與對(duì)象的具體實(shí)現(xiàn)連接起來(lái)。通過(guò)這種方式,客戶只要獲得了接口指針,就可以調(diào)用到對(duì)象的實(shí)際功能。


對(duì)于一個(gè)接口來(lái)說(shuō),他的虛函數(shù)表vtable是確定的,因此接口的成員函數(shù)個(gè)數(shù)是不變的,而且成員函數(shù)的先后順序也是不變的;對(duì)于每個(gè)成員函數(shù)來(lái)說(shuō),其參數(shù)和返回值也是確定的。


在一個(gè)接口的定義中,所有這些信息都必須在二進(jìn)制一級(jí)確定,不管什么語(yǔ)言,只要能支持這樣的內(nèi)存結(jié)構(gòu)描述,也就是能夠支持“structure“或“record“類型,并且這種類型能夠包含雙重的指向函數(shù)指針表的成員,則它就可以支持接口的描述,從而可以用于編寫COM組件或者使用COM組件。

接口描述語(yǔ)言IDL

COM規(guī)范在采用OSF的DCE規(guī)范描述遠(yuǎn)程調(diào)用接口IDL的基礎(chǔ)上,進(jìn)行擴(kuò)展形成了COM接口的描述語(yǔ)言。

COM規(guī)范使用的IDL接口描述語(yǔ)言不僅可用于定義COM接口,同時(shí)還定義了一些常用的數(shù)據(jù)類型,也可以描述自定義的數(shù)據(jù)結(jié)構(gòu),對(duì)于接口成員函數(shù),我們可以指定每個(gè)參數(shù)的類型,輸入輸出特性,甚至支持可變長(zhǎng)度的數(shù)組的描述。IDL支持指針類型,與C/C++很類似。

Microsoft Visual C++提供了MIDL工具,可以把IDL接口描述文件編譯成C/C++兼容的接口描述頭文件(.h)。

IUnknown的定義(IDL):

interface IUnknown
{

HRESULT QueryInterface([in] REFIID iid, [out] void **ppv);
ULONG AddRef(void);
ULONG Release(void);
}


IUnknown的定義(C++):

class IUnknown
{

Public:
virtual HRESULT _stdcall QueryInterface([in] REFIID iid, [out] void **ppv)=0;
virtual ULONG _stdcall AddRef(void)=0;
virtual ULONG _stdcall Release(void)=0;
}

進(jìn)程內(nèi)組件

因?yàn)檫M(jìn)程內(nèi)組件和客戶程序運(yùn)行在同一個(gè)進(jìn)程地址空間中,所以一旦客戶程序與組件程序建立起通信關(guān)系之后,客戶程序得到的接口指針指向組件程序中接口的vtable,這個(gè)vtable包含了所有成員函數(shù)地址,客戶代碼可以直接調(diào)用這些成員函數(shù),所以其效率非常高。

因?yàn)镈LL程序是在運(yùn)行時(shí)刻被客戶裝入到內(nèi)存中的,所以DLL模塊本身也是獨(dú)立的,它并不依賴于客戶程序。

在C++語(yǔ)言中,為了使編制的DLL程序更為通用,一般指定DLL的引出函數(shù)使用_stdcall調(diào)用習(xí)慣,如果使用了_cdecl調(diào)用習(xí)慣,則有些編程語(yǔ)言環(huán)境就不能使用這些DLL程序。C++編譯器為DLL程序的每個(gè)引出函數(shù)生成了一個(gè)修飾名,這些修飾名對(duì)于不同的編譯器并不兼容,因此,從通用性角度出發(fā),我們?cè)诿總€(gè)函數(shù)定義前加上extern ?C“ 說(shuō)明符。在Visual C++ 開發(fā)環(huán)境中,下面的說(shuō)明語(yǔ)句可以很好的說(shuō)明一個(gè)引出函數(shù):

extern ? C“ int _stdcall MyFunction(int n);

為了編制DLL程序,我們可以按照這樣的步驟:

(1) 創(chuàng)建一個(gè)DLL工程

(2) 對(duì)每個(gè)引出函數(shù),使用extern ? C“說(shuō)明符,以及_stdcall修飾符,如上面對(duì)MyFunction函數(shù)的說(shuō)明。

(3) 按照傳統(tǒng)的編程方法,我們還應(yīng)該編寫一個(gè)DEF文件,用來(lái)描述DLL程序的模塊信息。在Win32平臺(tái)上,我們可以不使用DEF文件,而是直接在函數(shù)說(shuō)明時(shí)使用_declspec(dllexport)說(shuō)明符,例如:

extern ? C“_declspec(dllexport) int _stdcall MyFunction(int n);

按照這樣的方法建立起來(lái)的DLL模塊可以被其他程序調(diào)用,因?yàn)镃++連接器會(huì)把所有引出函數(shù)的信息連接到最終的目標(biāo)代碼中。


從客戶程序一方來(lái)看,有三個(gè)系統(tǒng)函數(shù)可用于操作DLL程序,LoadLibrary, GetProcAddress, 和FreeLibrary。


一般地,對(duì)于DLL程序的使用過(guò)程按照這樣的步驟進(jìn)行:

首先,客戶程序使用LoadLibrary函數(shù)裝入DLL,該函數(shù)返回模塊的實(shí)例句柄,供以后操作該模塊使用。

然后,客戶程序可以調(diào)用GetProcAddress函數(shù)獲得DLL中引出的函數(shù)的地址,我們既可以按函數(shù)的序號(hào)(在DEF文件中指定)也可以按函數(shù)的名字來(lái)獲取引出函數(shù)的地址,因?yàn)榭蛻舫绦蚝虳LL程序在相同的內(nèi)存地址空間中,所以客戶程序可以直接調(diào)用這些引出函數(shù)。

最后FreeLibrary,把DLL程序卸出內(nèi)存,以便釋放資源。


說(shuō)明:

(1) DLL程序不僅可以引出函數(shù),也可以引出全局變量,因?yàn)榭蛻舫绦蚝虳LL程序在同一個(gè)地址空間,所以,把DLL中的全局變量引出到客戶程序中是有意義的。引用的方法并不復(fù)雜,或者把變量名放到DEF文件的EXPORTS部分,并加上DATA選項(xiàng); 或者在變量說(shuō)明前面加上_declspec(dllexport)說(shuō)明符。

(2) DumpBin 通過(guò)/Exports選項(xiàng)可以列出DLL程序中的所有被引出的信息。

(3) 客戶程序本身也可以是一個(gè)DLL程序,但它一定先被裝入到進(jìn)程空間中,以便可以調(diào)用系統(tǒng)函數(shù)操作作為服務(wù)程序的DLL模塊。

進(jìn)程外組件
因?yàn)檫M(jìn)程外組件程序和客戶程序位于不同的進(jìn)程空間之中,他們使用不同的地址空間,所以組件和客戶之間的通信必須跨越進(jìn)程邊界,這就涉及到以下一些問(wèn)題:

(1) 一個(gè)進(jìn)程如何調(diào)用另外一個(gè)進(jìn)程中的函數(shù)

(2) 參數(shù)如何從一個(gè)進(jìn)程被傳遞到另外一個(gè)進(jìn)程中

Windows平臺(tái)上,在不同進(jìn)程之間進(jìn)行通信的辦法很多,包括DDE, named pipe,或者共享內(nèi)存等等,COM采用了LPC(Local Procedure Call)和RPC(Remote Procedure Call)

RegEdit可檢查CLSID子鍵下的COM對(duì)象(63頁(yè))
Microsoft Visual C++提供OleView.exe,可列出當(dāng)前機(jī)器上的所有類別信息,以及每一種類別下的組件對(duì)象列表。

RegSvr32 D:\DicComp\DictComp.dll

RegSvr32 /u D:\DicComp\DictComp.dll

DLL組件必須有DllRegisterServer和DllUnregisterServer兩個(gè)用于注冊(cè)的入口函數(shù),才能用RegSvr32注冊(cè)。

COM規(guī)定,支持自注冊(cè)的進(jìn)程外組件必須支持兩個(gè)命令行參數(shù)/RegServer和/UnregServer,以便完成注冊(cè)或注銷操作。
Class Factory

實(shí)際上,客戶程序并不直接調(diào)用組件程序的引出函數(shù),它調(diào)用COM庫(kù)的函數(shù)進(jìn)行組件對(duì)象的創(chuàng)建工作,COM庫(kù)的創(chuàng)建函數(shù)根據(jù)注冊(cè)表的信息調(diào)用組件程序的入口函數(shù)來(lái)創(chuàng)建組件對(duì)象。組件程序需要提供一個(gè)標(biāo)準(zhǔn)的入口函數(shù)DLLGetObjectClass,用于提供本組程序的組件信息。

Class Factory和DLLGetObjectClass函數(shù)
類廠是COM對(duì)象的生產(chǎn)基地,COM庫(kù)通過(guò)類廠創(chuàng)建COM對(duì)象; 對(duì)應(yīng)每一個(gè)COM類,有一個(gè)類廠專門用于該COM類的對(duì)象創(chuàng)操作。類廠本身也是一個(gè)COM對(duì)象,它支持一個(gè)特殊的接口:IClassFactory,其定義如下:

Class IClassFactory : public IUnknown

{
virtual HRESULT _stdcall CreateInstance(IUnknown *pUnknownOuter, const IID& iid, void **ppv) = 0;
virtual HRESULT _stdcall LockServer(BOOL bLock) = 0;

};

接口IClassFactory有一個(gè)重要的成員函數(shù)CreateInstance,用于創(chuàng)建對(duì)應(yīng)的COM對(duì)象。因?yàn)槊總€(gè)類廠之針對(duì)特定的COM類對(duì)象,所以CreateInstance成員函數(shù)知道該創(chuàng)建什么樣的COM對(duì)象。在CreateInstance成員函數(shù)的參數(shù)中,第一個(gè)參數(shù)pUnknownOuter用于對(duì)象被聚合的情形,沒(méi)有聚合設(shè)成NULL。IClassFactory的另一個(gè)成員函數(shù)LockServer用于控制組建的生存周期。

因?yàn)轭悘S本身也是個(gè)COM對(duì)象,它被用于其它COM對(duì)象的創(chuàng)建過(guò)程,那么類廠對(duì)象又由誰(shuí)來(lái)創(chuàng)建呢?答案是DLLGetClassObject引出函數(shù)。DLLGetClassObject函數(shù)并不是COM庫(kù)的函數(shù),而是由組件程序?qū)崿F(xiàn)的引出函數(shù),我們先看一下DLLGetClassObject函數(shù)的原型:

HRESULT DLLGetClassObject(const CLSID& clsid,
Const IID& iid,
(void **) ppv
);

COM庫(kù)在接到對(duì)象創(chuàng)建的指令后,它要調(diào)進(jìn)程內(nèi)組件的DLLGetClassObject函數(shù),由該函數(shù)創(chuàng)類廠對(duì)象,并返回類廠對(duì)象的接口指針,COM庫(kù)或者客戶一旦有了類廠的接口指針,它們就可以通過(guò)類廠接口IClassFactory的成員函數(shù)CreateInstance創(chuàng)建相應(yīng)的COM對(duì)象。

COM庫(kù)與類廠的交互(67頁(yè))
在COM庫(kù)中,有三個(gè)API函數(shù)可用于對(duì)象的創(chuàng)建,它們分別是CoGetClassObject, CoCreateInstance和CoCreateInstanceEx。通常情況下,客戶程序調(diào)用其中之一完成對(duì)象的創(chuàng)建,并返回對(duì)象的初始接口指針。COM庫(kù)與類廠也通過(guò)這三個(gè)函數(shù)進(jìn)行交互。

posted on 2007-06-22 01:15 星夢(mèng)情緣 閱讀(34383) 評(píng)論(9)  編輯 收藏 引用 所屬分類: 關(guān)于編程

評(píng)論:
# re: COM組件簡(jiǎn)介 2007-06-22 23:30 | pass86
路過(guò)。  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2007-07-18 12:19 | 路過(guò)
寫的不錯(cuò),厲害  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2008-03-26 16:00 | 小不點(diǎn)
最近在看COM的基礎(chǔ)知識(shí)。。。
但是,對(duì)聚合有點(diǎn)難以理解。。。可否知道哈~~  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2008-10-14 09:54 | adf
太粗略  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2011-09-23 16:27 |
對(duì)我很幫助。。謝謝  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2012-07-20 16:47 | DDD
有幫助, 謝謝了  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2013-07-21 20:08 | 游客
剛剛學(xué)習(xí)com,感覺(jué)真的不錯(cuò)喲!  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2013-09-28 09:15 | 庚午月圓人
寫的不錯(cuò)  回復(fù)  更多評(píng)論
  
# re: COM組件簡(jiǎn)介 2016-02-16 15:59 | sadfdsa
學(xué)習(xí)了  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲第一精品福利| 亚洲欧美另类在线| 亚洲精品偷拍| 欧美国产一区二区在线观看| 欧美成人免费网站| 亚洲大片精品永久免费| 久久久久一本一区二区青青蜜月| 久久狠狠亚洲综合| 国内精品久久久久久久果冻传媒| 午夜精品久久久久99热蜜桃导演| 欧美一区三区三区高中清蜜桃| 欧美亚洲第一区| 亚洲一区久久| 久久午夜电影| 国内一区二区在线视频观看| 久久久天天操| 亚洲二区在线视频| 在线亚洲一区观看| 国产精品红桃| 久久精品国产亚洲一区二区三区| 另类尿喷潮videofree| 最新国产拍偷乱拍精品| 欧美久久精品午夜青青大伊人| 亚洲毛片一区| 久久九九全国免费精品观看| 亚洲高清网站| 欧美日韩亚洲一区二区三区| 亚洲欧美国产另类| 欧美成人免费播放| 亚洲欧美日韩另类| 亚洲国产日韩欧美在线动漫| 欧美三级不卡| 久久er99精品| 免费成人av资源网| 一本久久综合| 国产日韩综合| 欧美日韩国产一区二区三区地区| 亚洲综合第一页| 欧美激情一区在线观看| 亚洲欧美区自拍先锋| 在线欧美亚洲| 国产精品久久久久久av福利软件 | 最近看过的日韩成人| 在线亚洲一区| 1769国内精品视频在线播放| 欧美性猛交xxxx乱大交蜜桃 | 久久精品免费| 99亚洲精品| 老司机一区二区三区| 亚洲男人影院| 日韩视频永久免费| 狠狠色噜噜狠狠狠狠色吗综合| 欧美精品三级日韩久久| 久久精品一区二区三区不卡| 亚洲高清在线| 麻豆成人小视频| 欧美专区在线| 亚洲一区二区网站| 亚洲精品美女在线| 永久555www成人免费| 国产日韩欧美a| 欧美性大战久久久久| 免费av成人在线| 亚洲欧美日韩一区在线| 亚洲国产精品黑人久久久| 欧美在线免费一级片| 9久草视频在线视频精品| 亚洲电影网站| 国产资源精品在线观看| 国产精品网红福利| 欧美日韩一区二区三区在线视频| 免费日韩视频| 久久午夜视频| 久久久视频精品| 久久久久高清| 久久久精品性| 久久久精品tv| 久久国产精品高清| 久久av一区二区三区漫画| 亚洲欧美国产va在线影院| 亚洲最黄网站| 亚洲精品美女在线| 亚洲人成网站在线播| 亚洲激情第一页| 91久久综合| 亚洲免费成人av| 亚洲免费观看| 夜夜躁日日躁狠狠久久88av| 亚洲激情综合| 亚洲美女在线一区| 一区二区国产日产| 亚洲综合精品自拍| 亚洲在线成人| 欧美在线观看一二区| 欧美在线你懂的| 小黄鸭精品aⅴ导航网站入口| 一区二区不卡在线视频 午夜欧美不卡在 | 久久av二区| 久久精品免视看| 久久午夜电影网| 欧美国产精品劲爆| 欧美区视频在线观看| 欧美日韩色婷婷| 国产精品三级久久久久久电影| 国产精品激情| 国内偷自视频区视频综合| 国内精品久久久久伊人av| 影音先锋久久| 99re热这里只有精品免费视频| 一区二区日本视频| 午夜亚洲性色视频| 老司机午夜免费精品视频| 亚洲高清久久久| 一区二区三区|亚洲午夜| 一区二区三区国产盗摄| 欧美在线视频观看| 欧美不卡福利| 国产精品天天摸av网| 在线成人黄色| 亚洲天堂偷拍| 久久最新视频| 亚洲精品美女免费| 性亚洲最疯狂xxxx高清| 欧美不卡三区| 国产精品一区视频| 亚洲黄网站黄| 欧美一区激情| 久久天天躁狠狠躁夜夜av| 亚洲韩国精品一区| 亚洲欧美在线免费观看| 免费成人美女女| 国产伦精品一区二区三区视频黑人| 精品不卡一区二区三区| 一本色道久久88精品综合| 欧美影院成人| 日韩视频一区二区在线观看 | 国产欧美午夜| 日韩视频久久| 久久先锋资源| 在线亚洲美日韩| 欧美.www| 国产婷婷一区二区| 一区二区不卡在线视频 午夜欧美不卡在 | 国产精品无码永久免费888| 亚洲国产日韩一级| 欧美一区二区久久久| 亚洲人体偷拍| 久久综合久久综合这里只有精品 | 国产女主播一区| 99人久久精品视频最新地址| 久久精品人人爽| 最新高清无码专区| 久久se精品一区精品二区| 欧美网站在线观看| 亚洲九九九在线观看| 鲁大师影院一区二区三区| 亚洲一区二区三区高清不卡| 欧美韩国一区| 亚洲国产精品va在看黑人| 久久中文字幕一区| 久久久久久久久久久成人| 极品日韩av| 免费成人黄色片| 久久综合九色| 亚洲精品美女91| 亚洲三级电影全部在线观看高清| 欧美不卡视频| 一区二区三区欧美在线观看| 日韩亚洲视频| 国产精品毛片一区二区三区| 亚洲欧美日韩一区在线| 亚洲一区二区三区777| 国产精品一区免费视频| 久久精品在线免费观看| 久久九九免费视频| 亚洲国产第一| 亚洲精品国偷自产在线99热| 欧美日韩一区高清| 小黄鸭精品密入口导航| 欧美一区精品| 亚洲经典自拍| 99视频精品免费观看| 国产精品视频免费观看| 久久午夜影视| 欧美激情一区二区三级高清视频| 亚洲视频一二三| 亚洲欧美精品一区| 一区视频在线看| 亚洲欧洲综合| 国产伦精品一区二区三区四区免费| 久久人91精品久久久久久不卡| 久久麻豆一区二区| 99pao成人国产永久免费视频| 在线一区二区三区四区| 国内精品久久久久影院色| 亚洲国产婷婷| 国产欧美日韩亚洲| 亚洲国产成人在线视频| 国产九九精品视频| 亚洲大胆av|