今日粗看boost的代碼,發(fā)現(xiàn)很多類都繼承noncopyable,以下是noncopyable的代碼:
class noncopyable
{
protected:
noncopyable() {}
~noncopyable() {}
private: // emphasize the following members are private
noncopyable( const noncopyable& );
const noncopyable& operator=( const noncopyable& );
};
這里的設(shè)計思想是讓子類繼承,但是阻止子類調(diào)用賦值和copy構(gòu)造函數(shù),有什么用呢?
寫代碼的時候我經(jīng)常喜歡用singleton模式,比如那些工廠類,管理者類之類的,但是寫這些
singleton的時候當(dāng)然是希望全局只有一個,而且不希望別人在用的時候又自己創(chuàng)造一個,往往
就要每寫一個singleton類就要在類的declaration中把它們的構(gòu)造函數(shù),賦值函數(shù),析構(gòu)函數(shù),copy構(gòu)造函數(shù)隱藏到
private或者protected之中,這樣真的很累。
現(xiàn)在好了,只要讓這些singleton直接繼承noncopyable就ok了。這樣至少可以不用多寫賦值和copy構(gòu)造
函數(shù)了;構(gòu)造和析構(gòu)函數(shù)看情況而定了。
class noncopyable的基本思想是把構(gòu)造函數(shù)和析構(gòu)函數(shù)設(shè)置protected權(quán)限,這樣子類可以調(diào)用,但是外面的類不能調(diào)用,
那么當(dāng)子類需要定義構(gòu)造函數(shù)的時候不至于通不過編譯。但是最關(guān)鍵的是noncopyable把copy構(gòu)造函數(shù)和copy賦值函數(shù)做成了
private,這就意味著除非子類定義自己的copy構(gòu)造和賦值函數(shù),否則在子類沒有定義的情況下,外面的調(diào)用者是不能夠通過
賦值和copy構(gòu)造等手段來產(chǎn)生一個新的子類對象的。舉個簡單的例子:
class Test : public noncopyable
{
};
void main()
{
Test a,c;
Test b(a); ///<------(1) error
c = a; ///<------(2) error
}
如果Test類沒有繼承 noncopyable,那么(1)和(2)都可以通過編譯,但是一旦Test繼承了noncopyable,則(1)和(2)都通不過
編譯,從而可以防止調(diào)用者寫一些錯誤的代碼,這不正是我們做singleton對象所需要的嗎?