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

            C++ Programmer's Cookbook

            {C++ 基礎(chǔ)} {C++ 高級} {C#界面,C++核心算法} {設(shè)計(jì)模式} {C#基礎(chǔ)}

            模式設(shè)計(jì)c#--結(jié)構(gòu)型--Adapter

            名稱 Adapter
            結(jié)構(gòu) o_adapter.bmp

            ?
            意圖 將一個類的接口轉(zhuǎn)換成客戶希望的另外一個接口。A d a p t e r 模式使得原本由于接口不兼容而不能一起工作的那些類可以一起工作。
            適用性
            • 你想使用一個已經(jīng)存在的類,而它的接口不符合你的需求。
            • 你想創(chuàng)建一個可以復(fù)用的類,該類可以與其他不相關(guān)的類或不可預(yù)見的類(即那些接口可能不一定兼容的類)協(xié)同工作。
            • (僅適用于對象A d a p t e r )你想使用一些已經(jīng)存在的子類,但是不可能對每一個都進(jìn)行子類化以匹配它們的接口。對象適配器可以適配它的父類接口。

            Code Example
            OurAdapter聚集了FrameworkXTraget 和FrameworkYTarget的功能.
            namespace?Adapter_DesignPattern
            {
            ????
            using?System;

            ????
            class?FrameworkXTarget?
            ????
            {
            ????????
            virtual?public?void?SomeRequest(int?x)
            ????????
            {
            ????????????
            //?normal?implementation?of?SomeRequest?goes?here????????????????????
            ????????}

            ????}


            ????
            class?FrameworkYAdaptee
            ????
            {
            ????????
            public?void?QuiteADifferentRequest(string?str)?
            ????????
            {
            ????????????Console.WriteLine(
            "QuiteADifferentRequest?=?{0}",?str);
            ????????}
            ????????
            ????}


            ????
            class?OurAdapter?:?FrameworkXTarget
            ????
            {
            ????????
            private?FrameworkYAdaptee?adaptee?=?new?FrameworkYAdaptee();
            ????????
            override?public?void?SomeRequest(int?a)
            ????????
            {
            ????????????
            string?b;
            ????????????b?
            =?a.ToString();
            ????????????adaptee.QuiteADifferentRequest(b);
            ????????}
            ????????
            ????}


            ????
            ///?<summary>
            ????
            ///????Summary?description?for?Client.
            ????
            ///?</summary>

            ????public?class?Client
            ????
            {
            ????????
            void?GenericClientCode(FrameworkXTarget?x)
            ????????
            {
            ????????????
            //?We?assume?this?function?contains?client-side?code?that?only?
            ????????????
            //?knows?about?FrameworkXTarget.
            ????????????x.SomeRequest(4);
            ????????????
            //?other?calls?to?FrameworkX?go?here
            ????????????
            //?
            ????????}

            ????????
            ????????
            public?static?int?Main(string[]?args)
            ????????
            {
            ????????????Client?c?
            =?new?Client();
            ????????????FrameworkXTarget?x?
            =?new?OurAdapter();
            ????????????c.GenericClientCode(x);????
            ????????????
            return?0;
            ????????}

            ????}

            }


            通過繼承Target和成員Adaptee 的適配方式,使Adapter 最終滿足我們的需要!
            //?Adapter?pattern?--?Structural?example??


            using?System;

            namespace?DoFactory.GangOfFour.Adapter.Structural
            {

            ??
            //?Mainapp?test?application?

            ??
            class?MainApp
            ??
            {
            ????
            static?void?Main()
            ????
            {
            ??????
            //?Create?adapter?and?place?a?request?
            ??????Target?target?=?new?Adapter();
            ??????target.Request();

            ??????
            //?Wait?for?user?
            ??????Console.Read();
            ????}

            ??}


            ??
            //?"Target"?

            ??
            class?Target
            ??
            {
            ????
            public?virtual?void?Request()
            ????
            {
            ??????Console.WriteLine(
            "Called?Target?Request()");
            ????}

            ??}


            ??
            //?"Adapter"?

            ??
            class?Adapter?:?Target
            ??
            {
            ????
            private?Adaptee?adaptee?=?new?Adaptee();

            ????
            public?override?void?Request()
            ????
            {
            ??????
            //?Possibly?do?some?other?work?
            ??????
            //?and?then?call?SpecificRequest?
            ??????adaptee.SpecificRequest();
            ????}

            ??}


            ??
            //?"Adaptee"?

            ??
            class?Adaptee
            ??
            {
            ????
            public?void?SpecificRequest()
            ????
            {
            ??????Console.WriteLine(
            "Called?SpecificRequest()");
            ????}

            ??}

            }

            ?

            上面例子可以認(rèn)為是對象的Adapter模式, 因?yàn)閠arget為一個實(shí)際的類,不是一個接口
            以下為類的Adapter設(shè)計(jì)模式: 因?yàn)閠arget 為一個接口,又接口規(guī)范,且沒有實(shí)例成員
            //??Class?Adapter?pattern?--?Structural?example??
            using?System;

            //?"ITarget"
            interface?ITarget
            {
            ??
            //?Methods
            ??void?Request();
            }


            //?"Adaptee"
            class?Adaptee
            {
            ??
            //?Methods
            ??public?void?SpecificRequest()
            ??
            {
            ????Console.WriteLine(
            "Called?SpecificRequest()"?);
            ??}

            }


            //?"Adapter"
            class?Adapter?:?Adaptee,?ITarget
            {
            ??
            //?Implements?ITarget?interface
            ??public?void?Request()
            ??
            {
            ????
            //?Possibly?do?some?data?manipulation
            ????
            //?and?then?call?SpecificRequest
            ????this.SpecificRequest();
            ??}

            }


            /**////?<summary>
            ///?Client?test
            ///?</summary>

            public?class?Client
            {
            ??
            public?static?void?Main(string[]?args)
            ??
            {
            ????
            //?Create?adapter?and?place?a?request
            ????ITarget?t?=?new?Adapter();
            ????t.Request();
            ??}

            }


            總結(jié): 類適配器比對象適配器更好

            ???????? 類適配器提供了接口規(guī)范,
            ???????? 但是對象適配器沒有,如果target改變接口的話,adaper可能沒有跟著改變,最后導(dǎo)致error.也又可能會錯用target里的實(shí)例成員.

            posted on 2006-01-03 15:41 夢在天涯 閱讀(1022) 評論(3)  編輯 收藏 引用 所屬分類: Design pattern

            評論

            # re: 模式設(shè)計(jì)c#--結(jié)構(gòu)型--Adapter 2006-04-24 14:14 夢在天涯

            在以下各種情況下使用適配器模式:

            1、 系統(tǒng)需要使用現(xiàn)有的類,而此類的接口不符合系統(tǒng)的需要。
            2、 想要建立一個可以重復(fù)使用的類,用于與一些彼此之間沒有太大關(guān)聯(lián)的一些類,包括一些可能在將來引進(jìn)的類一起工作。這些源類不一定有很復(fù)雜的接口。
            3、 (對對象適配器而言)在設(shè)計(jì)里,需要改變多個已有子類的接口,如果使用類的適配器模式,就要針對每一個子類做一個適配器,而這不太實(shí)際。
              回復(fù)  更多評論   

            # re: 模式設(shè)計(jì)c#--結(jié)構(gòu)型--Adapter 2006-04-24 14:15 夢在天涯

            Adapter模式在實(shí)現(xiàn)時有以下這些值得注意的地方:

            1、 目標(biāo)接口可以省略,模式發(fā)生退化。但這種做法看似平庸而并不平庸,它可以使Adaptee不必實(shí)現(xiàn)不需要的方法(可以參考Default Adapter模式)。其表現(xiàn)形式就是父類實(shí)現(xiàn)缺省方法,而子類只需實(shí)現(xiàn)自己獨(dú)特的方法。這有些像模板(Template)模式。
            2、 適配器類可以是抽象類。
            3、 帶參數(shù)的適配器模式。使用這種辦法,適配器類可以根據(jù)參數(shù)返還一個合適的實(shí)例給客戶端。
              回復(fù)  更多評論   

            # re: 模式設(shè)計(jì)c#--結(jié)構(gòu)型--Adapter 2006-04-24 16:01 夢在天涯

            和代理模式的區(qū)別:  回復(fù)  更多評論   

            公告

            EMail:itech001#126.com

            導(dǎo)航

            統(tǒng)計(jì)

            • 隨筆 - 461
            • 文章 - 4
            • 評論 - 746
            • 引用 - 0

            常用鏈接

            隨筆分類

            隨筆檔案

            收藏夾

            Blogs

            c#(csharp)

            C++(cpp)

            Enlish

            Forums(bbs)

            My self

            Often go

            Useful Webs

            Xml/Uml/html

            搜索

            •  

            積分與排名

            • 積分 - 1804430
            • 排名 - 5

            最新評論

            閱讀排行榜

            狠狠色丁香久久婷婷综合蜜芽五月 | 99久久精品这里只有精品| 欧美性大战久久久久久| 91久久精品视频| 精品一区二区久久| 久久久久99这里有精品10 | 久久天天日天天操综合伊人av| 狠狠色噜噜色狠狠狠综合久久 | 伊人久久大香线蕉精品| 久久无码国产专区精品| 久久久久久久免费视频| 中文成人无码精品久久久不卡| 久久国产精品久久| 久久人人爽人人爽人人片av高请| 国产999精品久久久久久| 精品无码久久久久国产| AV狠狠色丁香婷婷综合久久| 国产成人精品免费久久久久| 国产精品久久久久久久久鸭| 久久AV高清无码| 国产精品久久久久9999高清| 国产精品久久久久久久久鸭| 久久国产精品成人免费| 久久国产热这里只有精品| 香蕉久久AⅤ一区二区三区| 久久精品日日躁夜夜躁欧美| 久久久久人妻一区精品色| 久久精品国产秦先生| 99久久精品免费国产大片| 亚洲国产成人久久综合野外| 777午夜精品久久av蜜臀| 国内精品久久久久影院日本| 狠狠久久综合| 99久久精品免费看国产一区二区三区 | 久久av免费天堂小草播放| 无码8090精品久久一区| 狠狠综合久久综合88亚洲| 久久国产亚洲高清观看| 久久久99精品一区二区| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 国产精品久久久久久久久鸭|