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

有同事很喜歡用Context模式,覺(jué)得是自己"首創(chuàng)", 我有些自己的想法, 或者大家可以發(fā)表下自己的觀(guān)點(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 閱讀(5492) 評(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)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美黄色片免费观看| 国产亚洲永久域名| 亚洲精选在线| 在线一区亚洲| 国产精品一区二区三区四区 | 国产精品色在线| 亚洲欧美国产精品桃花| 久久久综合激的五月天| 亚洲动漫精品| 欧美人与性动交cc0o| 亚洲调教视频在线观看| 久久精品国产欧美亚洲人人爽| 国产一区视频网站| 欧美大片免费观看| 亚洲综合视频1区| 麻豆91精品91久久久的内涵| 日韩小视频在线观看| 国产精品一区二区在线观看不卡| 久久久国产午夜精品| 亚洲人成人99网站| 欧美亚洲视频| 91久久国产综合久久蜜月精品| 欧美日本一道本在线视频| 午夜精品久久| 亚洲国产清纯| 欧美一区二区三区四区在线观看| 亚洲黄色影片| 国产精品一区免费视频| 免费永久网站黄欧美| 亚洲午夜高清视频| 欧美国产日韩在线| 欧美伊人影院| 一区二区三区免费在线观看| 韩日精品在线| 国产精品成人在线| 美女性感视频久久久| 亚洲视频免费在线观看| 欧美成人一区二区三区| 亚洲欧美亚洲| 99精品视频免费| 精品二区久久| 国产精品稀缺呦系列在线| 欧美精品激情blacked18| 久久久7777| 午夜激情一区| 夜夜爽99久久国产综合精品女不卡| 久久一区二区三区av| 亚洲欧美另类在线观看| 日韩视频精品| 一色屋精品视频在线观看网站| 国产精品激情av在线播放| 免费高清在线一区| 久久激情综合网| 亚洲一级在线| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产91| 免费亚洲电影| 六月天综合网| 久久天天综合| 久久夜色精品亚洲噜噜国产mv| 亚洲影视九九影院在线观看| 亚洲最黄网站| 99国产精品99久久久久久粉嫩 | 欧美不卡视频一区发布| 久久国产精品99久久久久久老狼| 亚洲欧美成人一区二区在线电影 | 国产免费观看久久黄| 国产精品黄页免费高清在线观看| 欧美日韩精品欧美日韩精品一| 欧美刺激午夜性久久久久久久| 巨乳诱惑日韩免费av| 久久亚洲精选| 蜜臀久久99精品久久久久久9| 久久久蜜桃精品| 久久久久久一区二区| 久热精品视频在线观看| 牛牛国产精品| 欧美—级高清免费播放| 欧美精品一区二区视频| 欧美日韩精品| 国产精品扒开腿做爽爽爽软件| 国产精品久久久久久影视| 国产精品va| 国产欧美日韩视频在线观看| 国产欧美日韩亚洲| 极品少妇一区二区三区精品视频| 激情一区二区三区| 亚洲人成在线播放| 一区二区三区不卡视频在线观看 | 91久久精品国产91性色| 日韩亚洲欧美一区二区三区| 日韩一区二区福利| 午夜欧美精品| 久久久综合香蕉尹人综合网| 欧美成人一二三| 欧美午夜激情在线| 国产在线不卡| 亚洲精品视频免费| 亚洲欧美日韩在线观看a三区| 久久国产日本精品| 亚洲第一精品福利| 中日韩美女免费视频网址在线观看| 亚洲永久在线| 另类av导航| 国产精品久久久一本精品| 韩国欧美一区| 99riav1国产精品视频| 欧美亚洲视频一区二区| 欧美成人精品一区二区三区| 亚洲免费电影在线| 久久成人综合视频| 欧美激情欧美激情在线五月| 国产午夜精品一区二区三区欧美| 亚洲电影在线看| 亚洲欧美色一区| 欧美福利一区| 午夜精品视频一区| 欧美黄色一级视频| 国产一区二区你懂的| 亚洲精品免费在线| 久久久久久免费| 日韩一级在线| 免费影视亚洲| 国产曰批免费观看久久久| 正在播放亚洲一区| 免费人成精品欧美精品| 亚洲性视频h| 欧美激情偷拍| 精品二区久久| 久久精品道一区二区三区| 日韩视频在线一区二区三区| 久久天天躁夜夜躁狠狠躁2022 | 午夜精品亚洲| 欧美日韩一区二区在线播放| 在线成人av.com| 久久国产精品高清| aa国产精品| 欧美精品日本| 亚洲韩日在线| 久久午夜视频| 欧美亚洲一区在线| 国产精品欧美风情| 这里只有精品在线播放| 欧美国产视频日韩| 久久久久国产精品一区三寸| 国产欧美日韩在线视频| 亚洲欧美日韩第一区| 日韩亚洲成人av在线| 欧美激情视频网站| 亚洲国产一区二区三区青草影视 | 亚洲国产99| 久久―日本道色综合久久| 国产日产欧美a一级在线| 亚洲欧美日本精品| 在线视频一区观看| 欧美色一级片| 亚洲一区二区三| 日韩视频第一页| 欧美日韩在线视频一区| a4yy欧美一区二区三区| 亚洲精品男同| 欧美乱妇高清无乱码| 日韩小视频在线观看专区| 亚洲国产精品激情在线观看| 麻豆久久精品| 亚洲日韩视频| 亚洲精品免费电影| 欧美日韩直播| 午夜精品久久久久久久99樱桃| 日韩一区二区免费看| 国产精品草草| 欧美一区影院| 久久久噜噜噜久久狠狠50岁| 亚洲第一级黄色片| 亚洲二区视频在线| 免费在线观看日韩欧美| 日韩手机在线导航| 在线一区二区日韩| 国产欧美欧洲在线观看| 久久久精品tv| 开元免费观看欧美电视剧网站| 亚洲日本理论电影| 日韩西西人体444www| 国产农村妇女精品| 免费在线成人av| 欧美激情bt| 亚洲欧美激情诱惑| 欧美中日韩免费视频| 亚洲欧洲三级| 在线一区日本视频| 激情综合电影网| 亚洲精品在线视频| 国产色综合久久| 亚洲第一在线| 国产精品女主播| 欧美mv日韩mv亚洲| 欧美日韩另类字幕中文| 欧美在线视频日韩| 欧美99久久| 亚洲欧美中文字幕|