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

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

什么是Context模式?

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

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

大概類圖如下:





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

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

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

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

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

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

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

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

FeedBack:
# re: 關(guān)于 "Context" 模式
2013-11-23 08:58 | 萬連文
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
@萬連文
嗯,確實(shí)度是關(guān)鍵, 實(shí)際上怎樣才算一個(gè)模塊? 它的粒度可以是個(gè)小的靜態(tài)Library, 也可能是個(gè)龐大的Service。最關(guān)鍵的就是要保持模塊的獨(dú)立性和層次性,避免形成網(wǎng)狀依賴。
  回復(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>
            国产亚洲综合性久久久影院| 欧美一区二区三区另类 | 国产精品yjizz| 久久九九99| 久久久成人精品| 蜜臀a∨国产成人精品 | 国产亚洲观看| 伊人婷婷久久| 一区二区欧美在线| 欧美专区日韩视频| 亚洲第一二三四五区| 91久久久久久国产精品| 亚洲视频国产视频| 久久久久在线观看| 欧美四级电影网站| 狠狠色狠狠色综合日日tαg | 久久免费精品视频| 欧美三级午夜理伦三级中文幕 | 日韩视频在线一区| 久久精品免费观看| 亚洲精品小视频| 久久成人一区| 欧美午夜国产| 亚洲欧洲另类| 欧美在线视频观看| 亚洲精品在线视频| 久久久一本精品99久久精品66| 欧美国产日产韩国视频| 国产亚洲欧美日韩美女| 一区二区三区四区五区在线| 久久久久久久久蜜桃| 一区二区毛片| 欧美bbbxxxxx| 在线观看欧美视频| 欧美一区二区高清| 日韩一二三区视频| 欧美精品尤物在线| 亚洲高清视频一区二区| 久久国产精品99久久久久久老狼| 亚洲精品久久久久久久久| 久久久亚洲影院你懂的| 国产视频在线观看一区| 亚洲专区免费| 亚洲最新合集| 欧美日韩国产成人高清视频| 在线视频国内自拍亚洲视频| 久久精品免费电影| 亚洲欧美在线aaa| 国产精品久久久久久av福利软件| 亚洲精选一区| 亚洲国产欧美一区二区三区久久| 久久久久久久久岛国免费| 亚洲免费在线精品一区| 欧美久久久久| 亚洲日本精品国产第一区| 免费看亚洲片| 久久午夜电影| 亚洲国产导航| 亚洲大胆视频| 欧美极品在线视频| 一道本一区二区| 亚洲欧洲综合另类| 欧美久久视频| 亚洲淫性视频| 亚洲一区亚洲| 国产综合在线看| 蜜臀久久99精品久久久画质超高清| 西瓜成人精品人成网站| 国内外成人免费视频| 久热精品在线| 免费成人性网站| 99视频+国产日韩欧美| 日韩一区二区精品在线观看| 欧美午夜精品伦理| 久久se精品一区二区| 久久精品电影| 亚洲美女免费精品视频在线观看| 亚洲国产一区在线观看| 国产精品观看| 久久久噜噜噜| 欧美电影在线观看完整版| 这里只有精品丝袜| 午夜精品久久久久久久久| 影音先锋日韩资源| 亚洲理论在线观看| 国产日韩精品一区| 欧美激情在线播放| 国产精品久久久久久久久免费樱桃 | 亚洲日本无吗高清不卡| 欧美午夜精品电影| 久久影院亚洲| 欧美私人啪啪vps| 久久最新视频| 国产精品vip| 欧美成人精品一区| 国产精品久久一区主播| 免费永久网站黄欧美| 欧美性猛交xxxx乱大交退制版 | 国产在线麻豆精品观看| 欧美激情无毛| 国产老肥熟一区二区三区| 欧美成年网站| 国产偷自视频区视频一区二区| 欧美国产免费| 国产一区二区三区av电影| 亚洲激情在线观看| 狠狠干成人综合网| 亚洲午夜电影在线观看| 亚洲欧洲一区二区三区| 欧美在线视频一区二区三区| 尤物网精品视频| 一区二区欧美激情| 亚洲欧美在线磁力| 一区二区久久久久久| 久久免费的精品国产v∧| 中文在线不卡| 欧美jjzz| 欧美激情性爽国产精品17p| 国产精品一香蕉国产线看观看| 亚洲二区三区四区| 狠狠干成人综合网| 欧美一区深夜视频| 欧美一级电影久久| 国产精品久久久久久久久久妞妞 | 久久精品国产亚洲一区二区| 欧美日韩视频在线| 亚洲精品色婷婷福利天堂| 亚洲电影av| 免费欧美日韩| 亚洲大胆女人| 亚洲欧洲综合| 欧美日韩大陆在线| 亚洲麻豆av| 亚洲视频香蕉人妖| 欧美日韩一区二区三区四区在线观看| 亚洲激情一区| 宅男噜噜噜66国产日韩在线观看| 欧美日韩国产影片| 在线亚洲精品| 欧美影院在线| 国产综合自拍| 你懂的亚洲视频| 亚洲精品免费一区二区三区| 一区二区三区高清不卡| 欧美三日本三级少妇三99| 亚洲网站在线播放| 久久精品日产第一区二区| 国内精品久久久久久影视8| 久久久久久久欧美精品| 欧美国产综合一区二区| 99精品久久久| 国产麻豆综合| 免费高清在线一区| 一本久道久久综合狠狠爱| 午夜精品美女久久久久av福利| 国产欧美视频在线观看| 久久久久国产精品一区| 亚洲经典三级| 午夜精品久久久久久99热| 国产亚洲激情在线| 免费91麻豆精品国产自产在线观看| 亚洲国产一区二区三区青草影视 | 蜜臀va亚洲va欧美va天堂| 亚洲黄色在线看| 国产精品都在这里| 久久久久久久波多野高潮日日| 亚洲第一级黄色片| 午夜亚洲视频| 亚洲欧洲午夜| 国产伦精品一区二区三区视频黑人 | 国内精品久久久久影院优| 久久久久女教师免费一区| 欧美激情精品久久久久| 亚洲性视频网站| 一区二区视频欧美| 欧美三日本三级少妇三99| 久久精品夜色噜噜亚洲aⅴ | 亚洲欧美国产va在线影院| 久久综合伊人| 亚洲欧美韩国| 91久久精品美女高潮| 国产精品嫩草久久久久| 开心色5月久久精品| 亚洲午夜精品一区二区三区他趣| 麻豆精品91| 欧美一区成人| 一本色道精品久久一区二区三区 | 国产精品高潮呻吟久久av黑人| 久久影院午夜论| 亚洲女同精品视频| 亚洲日本国产| 欧美激情精品久久久久久黑人| 久久不见久久见免费视频1| 一级成人国产| 亚洲美女黄网| 亚洲三级视频| 亚洲高清不卡| 有码中文亚洲精品| 国产日韩亚洲欧美| 国产伦精品免费视频 |