適配器(Adapter)模式接受一種類型并且提供一個(gè)對(duì)其他類型的接口。當(dāng)給定一個(gè)庫(kù)或者具有某一接口的一段代碼,同事還給定另外一個(gè)庫(kù)或者與前面那段代碼的基本思想相同的一段代碼而只是表達(dá)式不一致時(shí),適配器模式將十分有用。通過(guò)調(diào)整彼此的表達(dá)方式來(lái)適配彼此,將會(huì)迅速產(chǎn)生解決方法。
實(shí)例代碼如下:
//FibonacciGenerator.h, 斐波那契數(shù)列產(chǎn)生器類
#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
也許讀者希望利用這個(gè)產(chǎn)生器來(lái)執(zhí)行STL數(shù)值算法操作。遺憾的是,STL算法只能使用迭代器才能工作,這就存在接口不匹配的問(wèn)題。解決方法就是產(chǎn)生一個(gè)適配器。代碼如下。
#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;
}