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

            搜索

            •  

            積分與排名

            • 積分 - 1804434
            • 排名 - 5

            最新評論

            閱讀排行榜

            国产午夜精品久久久久九九电影| 久久久久亚洲av无码专区| 99久久精品免费看国产一区二区三区| 伊人久久大香线焦综合四虎| 日本福利片国产午夜久久| 久久综合色区| 97精品伊人久久大香线蕉app| 久久精品国产91久久综合麻豆自制| 久久久这里有精品中文字幕| 久久精品人妻中文系列| 777久久精品一区二区三区无码| 综合久久精品色| 国产精品嫩草影院久久| 久久久婷婷五月亚洲97号色| 久久国产成人亚洲精品影院| 久久ZYZ资源站无码中文动漫| 93精91精品国产综合久久香蕉| 亚洲中文久久精品无码| 久久性精品| 精品视频久久久久| 国产麻豆精品久久一二三| 国产精品99久久久精品无码 | 色天使久久综合网天天| 99久久超碰中文字幕伊人| 亚洲中文字幕久久精品无码APP| 久久久久久青草大香综合精品| 免费观看久久精彩视频| 久久人人妻人人爽人人爽| 久久毛片一区二区| 中文字幕精品久久久久人妻| 国产伊人久久| 久久久久久噜噜精品免费直播| 亚洲一本综合久久| 国产成人AV综合久久| 国产成人无码精品久久久免费| 国产99精品久久| 久久国产精品成人免费| 成人精品一区二区久久| 国产精品久久一区二区三区| 久久精品国产一区| 久久精品国产亚洲av瑜伽|