• <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>

            ATL COM初探(1)

             

            我沒有看過任何的COM書籍,以下總結均是我個人在ATL框架下的實驗所得,如有錯誤望指正。目前的實驗都是單進程中的,至于跨進程的實驗還未進行。

            Apartment:

            這是一個抽象的概念,我簡單的將其理解為作用域(COM對象的生存空間)。可以分為Single-Threaded Apartment(STA)和Multi-Threaded Apartment(MTA),至于Neutral Apartment, Thread Neutral Apartment, Neutral Threaded Apartment(NA, TNA, NTA)還沒接觸過。一個進程中可以存在多個STA,但只能存在一個MTA。創(chuàng)建COM對象所需要的Apartment類型不存在的時候,系統(tǒng)會自行創(chuàng)建。

            主STA:

            在進程中沒有任何STA的情況下,第一個初始化的STA(包括之前存在STA但已經(jīng)退出的情況)稱為主STA。在獲取(創(chuàng)建)單線程COM對象時,如果在沒有主STA的情況下(哪怕存在STA,但主STA退出了),系統(tǒng)會向RPC申請一個線程來創(chuàng)建一個主STA,換句話說就是STA是無法改變自身的主從屬性的,主從屬性從初始化的時刻其就決定了。系統(tǒng)進行同步的STA至少需要一個消息循環(huán),否則代理對象會被阻塞(系統(tǒng)創(chuàng)建的STA會自帶一個消息循環(huán))。

            單線程COM:

            只能存在于主STA,在非主STA中系統(tǒng)會使用代理對象進行訪問并利用窗口消息進行同步,也就是說只有主STA得到的是原始指針,其他的Apartment得到的均為代理指針。如果我們想將某個COM對象約束在某個線程中,那么這個模型是很適合的。只要這個線程初始化關聯(lián)主STA,那么這個模型的COM對象都會存在于這個線程了(因為一個STA作用域是不能跨線程的)。

            單元COM:

            存在于STA,在非所屬STA中系統(tǒng)會使用代理對象進行訪問并利用窗口消息進行同步,也就是說只有在STA中創(chuàng)建得到的是原始指針,Marshal得到的都是代理指針,MTA中創(chuàng)建得到的也是代理指針。

            兩者COM:

            STA和MTA創(chuàng)建均得到原始指針。在與對象的創(chuàng)建不同的Apartment中得到的將是代理指針(可以指定得到原始指針,但這會失去系統(tǒng)對STA對象的訪問同步),若創(chuàng)建的是STA對象,那么系統(tǒng)會利用窗口消息進行同步;若創(chuàng)建的是MTA對象,系統(tǒng)不會進行同步。

            自由COM:

            只存在于MTA,在STA中創(chuàng)建或者Marshal得到的都是代理指針,但系統(tǒng)不會進行同步。在MTA中創(chuàng)建和Marshal得到的都是原始指針。

            中性COM:

            STA和MTA創(chuàng)建均得到代理指針。Marshal得到的代理指針均為同一個指針,系統(tǒng)不會進行同步。只能得到代理指針可能是因為其只存在于NA中的緣故吧。

            作者: Evil.Ghost 發(fā)表于 2011-03-11 11:12 原文鏈接

            評論: 0 查看評論 發(fā)表評論


            最新新聞:
            · 蘋果iPad 2通過3C認證 最晚5月國內(nèi)上市(2011-04-10 09:18)
            · 盲目依賴iPhone等工具導航 英國驢友迷路多(2011-04-10 09:14)
            · 趣談:想擔任CEO的話,最好是去蘋果工作,其次是微軟,再才是Google(2011-04-10 08:26)
            · 騰訊將建立新數(shù)據(jù)中心,規(guī)模為蘋果的兩倍(2011-04-10 08:25)
            · 輕量化的微型博客Tumblr(2011-04-10 08:03)

            編輯推薦:非戰(zhàn)之罪,從永中Office談起

            網(wǎng)站導航:博客園首頁  我的園子  新聞  閃存  小組  博問  知識庫

            posted on 2011-03-11 11:12 EvilGhost 閱讀(408) 評論(0)  編輯 收藏 引用

            導航

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆檔案(12)

            文章檔案(1)

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            中文字幕乱码人妻无码久久| 久久婷婷五月综合色高清 | 波多野结衣久久一区二区| 久久精品国产WWW456C0M| 一本色道久久HEZYO无码| 丰满少妇人妻久久久久久4| 国产免费久久精品99re丫y| 亚洲乱亚洲乱淫久久| 狼狼综合久久久久综合网| 久久国产美女免费观看精品 | 久久精品国产久精国产一老狼| 国产精品久久网| 久久久久久精品久久久久| 国内精品久久久久久不卡影院| 久久综合狠狠综合久久| 一级a性色生活片久久无| 91亚洲国产成人久久精品网址 | 亚洲午夜久久久影院伊人| 久久夜色精品国产www| 久久精品这里热有精品| 久久人人爽人人爽人人片AV不 | 久久成人18免费网站| 91精品国产高清久久久久久91| 久久精品aⅴ无码中文字字幕重口| 一97日本道伊人久久综合影院| 久久996热精品xxxx| 国内精品久久久久久麻豆| 国产三级精品久久| 秋霞久久国产精品电影院| 国内精品久久人妻互换| 精品无码久久久久久尤物| 国产精品美女久久久m| 97久久超碰国产精品2021| 精品久久久久久久无码| 国产成年无码久久久久毛片| 72种姿势欧美久久久久大黄蕉| 久久久久成人精品无码中文字幕 | 久久亚洲精品国产亚洲老地址| 久久综合给合综合久久| 四虎久久影院| 亚洲AV日韩精品久久久久久久|