• <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>
            有同事很喜歡用Context模式,覺(jué)得是自己"首創(chuàng)", 我有些自己的想法, 或者大家可以發(fā)表下自己的觀點(diǎn)。

            什么是Context模式?

            23種設(shè)計(jì)模式中沒(méi)有這個(gè)模式, 是同事自己命名的, 我覺(jué)得名字也挺合理。

            Context模式首先要滿(mǎn)足的條件是類(lèi)都是基于COM思想IUnknown接口
            繼承于IUnknown有2個(gè)基本接口, 一個(gè)是IContext, 另外一個(gè)是IComponent
            IContext的作用是保存一個(gè)Map, 里面存有接口IID和接口指針的映射關(guān)系
            IComponent的作用是保存一份對(duì)IContext的引用, 通過(guò)IContext它可以查詢(xún)到任何保存在里面的接口
            任何比較" 大型“的接口和對(duì)象都從IComponent繼承,并在對(duì)象初始化時(shí)把自己存入IContext,
            這種設(shè)計(jì)的好處就是我們?cè)趯?shí)現(xiàn)對(duì)象時(shí)可以查詢(xún)到任何我們需要的接口。

            大概類(lèi)圖如下:





            上面的設(shè)計(jì)好處很明顯, 就是使用簡(jiǎn)單, 任何接口我們都可以查詢(xún)到, 我們?cè)趯?xiě)程序時(shí)應(yīng)該有這樣的體驗(yàn), 往往需要一個(gè)全局的CXXXApp對(duì)象實(shí)例, 然后我們可以通過(guò)這個(gè)對(duì)象實(shí)例, 一層層往下查詢(xún)到其他的對(duì)象和接口, MFC就是這么做的。如果我們用上面這個(gè)模式, 我們就不需要依賴(lài)于某個(gè)全局對(duì)象了, 因?yàn)槲覀兝^承的IComponent接口本身就有查詢(xún)其他對(duì)象的能力了。

            但這樣的設(shè)計(jì)也有一些缺陷:

            首先是多實(shí)例支持不了了, 因?yàn)槲覀兏鶕?jù)接口ID來(lái)查詢(xún)某個(gè)對(duì)象指針,一個(gè)接口實(shí)現(xiàn)類(lèi)的多個(gè)實(shí)例沒(méi)法存到IContext中; 多個(gè)類(lèi)可以實(shí)現(xiàn)同一接口, 這些類(lèi)實(shí)例對(duì)象也沒(méi)法存儲(chǔ)多個(gè)。COM里面除了IID, 還有CLSID來(lái)標(biāo)志實(shí)現(xiàn)類(lèi)。

            其次是耦合性, 盡管耦合是基于接口耦合, 依賴(lài)性已經(jīng)降到最低,但是還是在原本不需要耦合的地方產(chǎn)生了耦合, 把別人用不到接口暴露給他了。
            最后是復(fù)雜性, 因?yàn)镮Context里什么都可以查詢(xún)到, 所以我們會(huì)在不經(jīng)意間什么都向它要, 將原本設(shè)計(jì)時(shí)的單向依賴(lài)變成雙向依賴(lài), 最后演變成復(fù)雜的網(wǎng)狀依賴(lài), 最后對(duì)代碼徹底失去控制

            究竟什么時(shí)候該用這個(gè)模式? 我個(gè)人的建議是在小模塊內(nèi)部使用。

            模塊劃分首先強(qiáng)調(diào)層次性, 就是 單向依賴(lài), 上層依賴(lài)于下層, 積木式的層層堆砌。如果在模塊間傳遞Context指針, 很快會(huì)變成網(wǎng)狀依賴(lài), 對(duì)程序失去控制, 誰(shuí)知道別人拿了你這個(gè)IContext指針查詢(xún)了那些接口, 最后干嘛去了。

            大模塊內(nèi)部,除非模塊內(nèi)部層次很清楚, 你能很好的控制。一般我們也不建議使用Context模式, 因?yàn)椴恢挥X(jué)就會(huì)造成復(fù)雜的網(wǎng)狀依賴(lài),會(huì)對(duì)程序就會(huì)失去控制。

            對(duì)于對(duì)象和接口間的依賴(lài),不知道大家是怎么解決的? 我想大部分人應(yīng)該是通過(guò)全局對(duì)象或是顯式的傳遞需要的接口指針來(lái)做的。
            對(duì)于Context模式,大家怎么看?
            posted on 2013-11-22 23:29 Richard Wei 閱讀(5417) 評(píng)論(2)  編輯 收藏 引用 所屬分類(lèi): 設(shè)計(jì)模式

            FeedBack:
            # re: 關(guān)于 "Context" 模式
            2013-11-23 08:58 | 萬(wàn)連文
            IServiceProvider->IService->IComponent

            小模塊更明確直接使用最終的組件,大模塊需要能拿到全局的IServiceProvider以便調(diào)用需要的服務(wù)。總之需要權(quán)衡,度的拿捏是架構(gòu)關(guān)鍵。  回復(fù)  更多評(píng)論
              
            # re: 關(guān)于 "Context" 模式
            2013-11-23 14:11 | Richard Wei
            @萬(wàn)連文
            嗯,確實(shí)度是關(guān)鍵, 實(shí)際上怎樣才算一個(gè)模塊? 它的粒度可以是個(gè)小的靜態(tài)Library, 也可能是個(gè)龐大的Service。最關(guān)鍵的就是要保持模塊的獨(dú)立性和層次性,避免形成網(wǎng)狀依賴(lài)。
              回復(fù)  更多評(píng)論
              
            久久精品国产亚洲av水果派| 久久综合九色欧美综合狠狠| 中文字幕无码久久精品青草 | 久久超碰97人人做人人爱| 久久夜色精品国产| 久久99精品久久久久久不卡| 久久精品国产亚洲av日韩| 久久久久久夜精品精品免费啦| 中文字幕乱码人妻无码久久| 无码任你躁久久久久久老妇App| 午夜精品久久久久成人| 一级a性色生活片久久无少妇一级婬片免费放 | 国内精品久久久久国产盗摄| 51久久夜色精品国产| 99久久夜色精品国产网站| 久久精品国产一区二区三区不卡 | 久久久国产精品网站| 2021国产成人精品久久| 久久久久亚洲AV成人网人人网站 | 久久婷婷国产综合精品| 久久被窝电影亚洲爽爽爽| 99久久精品国产一区二区| 久久久久亚洲AV成人网人人网站| 久久久久久无码国产精品中文字幕 | 久久久黄色大片| 无码人妻精品一区二区三区久久 | 久久婷婷五月综合成人D啪| 久久国产亚洲精品| 久久无码人妻一区二区三区| 精品久久久久久久久中文字幕| 久久99精品久久久久久不卡| 伊人久久大香线蕉综合影院首页| 日韩av无码久久精品免费| 青青国产成人久久91网| 久久久久久久久久久| 久久99国产精品久久99| 久久久久久综合网天天| 精品久久久久久无码中文字幕| 中文字幕人妻色偷偷久久| 久久国产视屏| 久久精品无码一区二区三区|