• <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++ 基礎} {C++ 高級} {C#界面,C++核心算法} {設計模式} {C#基礎}

            模式設計c#--結構型--Adapter

            名稱 Adapter
            結構 o_adapter.bmp

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

            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()");
            ????}

            ??}

            }

            ?

            上面例子可以認為是對象的Adapter模式, 因為target為一個實際的類,不是一個接口
            以下為類的Adapter設計模式: 因為target 為一個接口,又接口規范,且沒有實例成員
            //??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();
            ??}

            }


            總結: 類適配器比對象適配器更好

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

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

            評論

            # re: 模式設計c#--結構型--Adapter 2006-04-24 14:14 夢在天涯

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

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

            # re: 模式設計c#--結構型--Adapter 2006-04-24 14:15 夢在天涯

            Adapter模式在實現時有以下這些值得注意的地方:

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

            # re: 模式設計c#--結構型--Adapter 2006-04-24 16:01 夢在天涯

            和代理模式的區別:  回復  更多評論   

            公告

            EMail:itech001#126.com

            導航

            統計

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

            常用鏈接

            隨筆分類

            隨筆檔案

            收藏夾

            Blogs

            c#(csharp)

            C++(cpp)

            Enlish

            Forums(bbs)

            My self

            Often go

            Useful Webs

            Xml/Uml/html

            搜索

            •  

            積分與排名

            • 積分 - 1807602
            • 排名 - 5

            最新評論

            閱讀排行榜

            亚洲日本va午夜中文字幕久久| 香蕉久久夜色精品升级完成| 久久99精品久久久久久久不卡| 久久亚洲中文字幕精品有坂深雪 | 久久天天躁狠狠躁夜夜96流白浆| 久久久久亚洲AV无码永不| 久久久久久久99精品免费观看| 久久精品国产91久久综合麻豆自制| 久久无码AV中文出轨人妻| 国产69精品久久久久观看软件| 日韩人妻无码精品久久免费一 | 91精品国产91久久久久久青草 | 亚洲狠狠婷婷综合久久蜜芽 | 久久精品九九亚洲精品| 91精品国产91久久久久久| 久久久久久久精品妇女99| 精品人妻久久久久久888| 亚洲国产日韩综合久久精品| 国产精品一区二区久久国产| 亚洲婷婷国产精品电影人久久| 国产精品久久久久久久久| 伊人久久成人成综合网222| 99久久精品日本一区二区免费| 日批日出水久久亚洲精品tv| 久久精品aⅴ无码中文字字幕重口| segui久久国产精品| 精品久久久久久无码专区| 久久久久国产精品人妻| 亚洲Av无码国产情品久久| 丰满少妇人妻久久久久久4| 久久久久久国产精品免费无码| 久久人人爽人人爽人人片AV麻烦| 久久精品国产影库免费看| 久久香蕉国产线看观看精品yw| 亚洲午夜精品久久久久久浪潮| 国产精品成人久久久久久久| 久久午夜无码鲁丝片| 色8久久人人97超碰香蕉987| 久久AV高潮AV无码AV| 精品久久久无码人妻中文字幕| 婷婷久久综合|