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

            Just enjoy programming

            c++設計模式(四)適配器(Adapter)模式

            適配器(Adapter)模式接受一種類型并且提供一個對其他類型的接口。當給定一個庫或者具有某一接口的一段代碼,同事還給定另外一個庫或者與前面那段代碼的基本思想相同的一段代碼而只是表達式不一致時,適配器模式將十分有用。通過調整彼此的表達方式來適配彼此,將會迅速產生解決方法。

            實例代碼如下:
            //FibonacciGenerator.h, 斐波那契數列產生器類

            #ifndef FIBONACCIGENERATOR_H
            #define FIBONACCIGENERATOR_H

            class FibonacciGenerator
            {
                int n;
                int val[2];
                public:
                    FibonacciGenerator():n(0){val[0]=val[1]=0;}
                    int operator()()
                    {
                        int result=n>2?val[0]+val[1]:n>0?1:0;
                        ++n;
                        val[0]=val[1];
                        val[1]=result;
                        return result;
                    }
                    int count(){return n;}
            };
            #endif

            也許讀者希望利用這個產生器來執行STL數值算法操作。遺憾的是,STL算法只能使用迭代器才能工作,這就存在接口不匹配的問題。解決方法就是產生一個適配器。代碼如下。
            #include<iostream>
            #include<numeric>
            #include"FibonacciGenerator.h"

            using namespace std;

            class FibonacciAdapter
            {
                FibonacciGenerator f;
                int length;
                public:
                    FibonacciAdapter(int size):length(size){}
                    class iterator;
                    friend class iterator;
                    class iterator:public std::iterator<std::input_iterator_tag,FibonacciAdapter,ptrdiff_t>
                    {
                        FibonacciAdapter& ap;
                        public:
                            typedef int value_type;
                            iterator(FibonacciAdapter &a):ap(a){}
                            bool operator==(const iterator &)const{
                                return ap.f.count()==ap.length;
                            }
                            bool operator!=(const iterator &x)const
                            {
                                return !(*this==x);
                            }

                            int operator*()const{return ap.f();}
                            iterator& operator++(){return *this;}
                            iterator operator++(int){return *this;}
                    };
                    iterator begin(){return iterator(*this);}
                    iterator end(){return iterator(*this);}
            };

            int main()
            {
                const int SZ=20;
                FibonacciAdapter a1(SZ);
                cout<<"accumulate:"<<accumulate(a1.begin(),a1.end(),0)<<endl;
            }



            posted on 2011-05-03 10:49 周強 閱讀(362) 評論(0)  編輯 收藏 引用 所屬分類: c/c++

            久久国产乱子伦精品免费强| 久久久久久国产精品美女| 日韩欧美亚洲国产精品字幕久久久 | 亚洲国产成人久久综合一区77| 久久本道久久综合伊人| 99久久国产综合精品女同图片| 精品久久8x国产免费观看| 久久99精品国产麻豆不卡| 亚洲狠狠婷婷综合久久蜜芽 | 久久久无码人妻精品无码| 一本大道加勒比久久综合| 久久天天躁狠狠躁夜夜avapp | 色偷偷91久久综合噜噜噜噜| 99久久夜色精品国产网站| 久久福利片| 国产精品成人久久久久三级午夜电影| 欧美无乱码久久久免费午夜一区二区三区中文字幕| 久久久久免费精品国产| 久久se精品一区精品二区国产| 亚洲AV无码久久精品狠狠爱浪潮| 国产精品VIDEOSSEX久久发布| 久久99精品久久只有精品| 偷窥少妇久久久久久久久| 精品久久久久一区二区三区| 97r久久精品国产99国产精| 日日躁夜夜躁狠狠久久AV| 久久午夜福利无码1000合集| 午夜视频久久久久一区| 久久久久国色AV免费观看| 久久亚洲日韩看片无码| 国产亚洲精久久久久久无码| 久久精品国产精品亚洲精品 | 日韩AV毛片精品久久久| 久久久精品午夜免费不卡| 99久久精品国产免看国产一区| 久久亚洲春色中文字幕久久久| 无码人妻久久一区二区三区免费| 成人久久免费网站| 久久婷婷五月综合色奶水99啪| 精品久久久久香蕉网| 久久精品国产亚洲一区二区|