• <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 夢在天涯 閱讀(1023) 評論(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

            搜索

            •  

            積分與排名

            • 積分 - 1804752
            • 排名 - 5

            最新評論

            閱讀排行榜

            一本久久免费视频| 91精品国产91久久综合| 国产产无码乱码精品久久鸭| 久久精品国产精品亚洲人人| 久久精品国产99国产电影网| 97精品久久天干天天天按摩| 久久亚洲日韩精品一区二区三区| 一级做a爰片久久毛片毛片| 久久无码一区二区三区少妇 | 中文字幕久久精品无码| 久久伊人五月丁香狠狠色| 久久久久久精品无码人妻| 伊人情人综合成人久久网小说| 狠狠色丁香婷婷久久综合| 精品久久久久久久久免费影院| 伊人久久精品无码av一区| 亚洲欧美成人综合久久久| 无码国产69精品久久久久网站 | 久久久久久无码Av成人影院 | 久久精品国产亚洲AV无码娇色 | 久久精品国产精品青草| 久久91精品综合国产首页| 久久亚洲精品无码播放| 97精品国产97久久久久久免费| 久久久婷婷五月亚洲97号色 | 人人狠狠综合久久亚洲| 日韩欧美亚洲综合久久| 国产亚洲精品自在久久| 国产激情久久久久影院老熟女| 一本一道久久a久久精品综合| 亚洲精品国精品久久99热一| 亚洲国产成人久久综合一 | 久久精品成人影院| 国产A三级久久精品| 狠狠色综合久久久久尤物| 日韩久久久久中文字幕人妻| 色诱久久久久综合网ywww| 国产精品99久久久久久www| 亚洲欧洲久久久精品| 97久久久久人妻精品专区| 中文字幕无码久久精品青草|