1.9 結(jié)合Policy Classes
當(dāng)你將policies組合起來時(shí),便是它們最有用的時(shí)候。舉例,若我們整打算設(shè)計(jì)一個(gè)泛型的smart pointer。我們分析有兩個(gè)policies:threading model(多線程模型)和check before dereference (提領(lǐng)前先檢驗(yàn)),于是可以這樣定義SmartPtr模板類。
1
2 template < Class T,
3 template <class> class CheckingPolicy,
4 template <class> class ThreadingModel
5 >
6 class SmartPtr;
我們可以這樣使用:
1
2 typedef SmartPtr<Widget, EnforceNoNull, Singlethreaded> SafeWigetPtr;
或者,
1 typedef SmartPtr<Widget, NoChecking, SingleThread> WidgetPTr;
一旦你設(shè)法把一個(gè)class分解成正交的policies,便可利用少量的代碼涵蓋大多數(shù)行為。
1.10 以Policy Classes 定制接口
templates的限制之一,你無法定制class的結(jié)構(gòu),只能定義其行為。而policy-based design支持結(jié)構(gòu)方面的定制。
通過一個(gè)結(jié)構(gòu)指針或者引用的聚合,或者依靠于繼承。都可以。
1.11 Policies的兼容性
假設(shè)有兩個(gè)SmartPtr:FastWidgetPtr是一個(gè)不需要檢驗(yàn)的指針,SafeWidgetPtr則必須在提領(lǐng)(dereference)前檢驗(yàn)。你能將一個(gè)FastWidgetPtr對象指派(賦值)給一個(gè)SafeWidgetPtr對象嗎?
Policies之間的彼此轉(zhuǎn)換,最好的方法是以Policy來控制SmartPtr對象之間的拷貝和初始化。如:
1 template<Class T, template<class> class CheckingPolicy>
2 class SmartPtr : public CheckingPolicy<T>
3 {
4 //
5 template<class T1, template<class> class CP1>
6 SmartPtr(const SmartPtr<T1, CP1>& other>
7 : pointee_(other.pointee_), CheckingPolicy<T>(other)
8 {//
}
9 };
本節(jié)后續(xù)內(nèi)容從略
1.12 將一個(gè)Class分解為一堆Policies
1.13 摘要