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

            搜索

            •  

            積分與排名

            • 積分 - 1804159
            • 排名 - 5

            最新評論

            閱讀排行榜

            久久久久高潮毛片免费全部播放| 亚洲AV日韩精品久久久久久久| 色偷偷偷久久伊人大杳蕉| 欧美亚洲国产精品久久高清| 久久久亚洲欧洲日产国码是AV | 亚洲伊人久久大香线蕉综合图片| 免费精品久久天干天干| 久久不见久久见免费视频7| 一本一道久久精品综合| 亚洲日韩欧美一区久久久久我| 人妻少妇久久中文字幕一区二区| 色综合久久久久| 国产精品成人久久久| 一级做a爰片久久毛片人呢| 久久乐国产综合亚洲精品| segui久久国产精品| 18岁日韩内射颜射午夜久久成人| segui久久国产精品| 亚洲AV乱码久久精品蜜桃| 午夜精品久久久久久| 国产精品免费久久久久影院| 一本久久a久久精品vr综合| 蜜桃麻豆www久久国产精品| 国产精品女同久久久久电影院| 久久精品无码一区二区三区日韩 | 国产精品女同久久久久电影院| 久久久精品国产亚洲成人满18免费网站| 无遮挡粉嫩小泬久久久久久久 | 国产精品免费久久| av午夜福利一片免费看久久| 欧美日韩精品久久久免费观看| 老司机国内精品久久久久| 久久精品无码专区免费青青| 中文字幕精品久久| 久久久国产精华液| 久久精品国产欧美日韩| 精品免费久久久久国产一区| 99久久综合国产精品二区| 久久综合中文字幕| 88久久精品无码一区二区毛片| 国产精品美女久久久|