今日粗看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è)計(jì)思想是讓子類繼承,但是阻止子類調(diào)用賦值和copy構(gòu)造函數(shù),有什么用呢?
寫代碼的時(shí)候我經(jīng)常喜歡用singleton模式,比如那些工廠類,管理者類之類的,但是寫這些
singleton的時(shí)候當(dāng)然是希望全局只有一個(gè),而且不希望別人在用的時(shí)候又自己創(chuàng)造一個(gè),往往
就要每寫一個(gè)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ù)的時(shí)候不至于通不過(guò)編譯。但是最關(guān)鍵的是noncopyable把copy構(gòu)造函數(shù)和copy賦值函數(shù)做成了
private,這就意味著除非子類定義自己的copy構(gòu)造和賦值函數(shù),否則在子類沒(méi)有定義的情況下,外面的調(diào)用者是不能夠通過(guò)
賦值和copy構(gòu)造等手段來(lái)產(chǎn)生一個(gè)新的子類對(duì)象的。舉個(gè)簡(jiǎn)單的例子:
class Test : public noncopyable
{
};
void main()
{
Test a,c;
Test b(a); ///<------(1) error
c = a; ///<------(2) error
}
如果Test類沒(méi)有繼承 noncopyable,那么(1)和(2)都可以通過(guò)編譯,但是一旦Test繼承了noncopyable,則(1)和(2)都通不過(guò)
編譯,從而可以防止調(diào)用者寫一些錯(cuò)誤的代碼,這不正是我們做singleton對(duì)象所需要的嗎?