条項14:ベースクラスに虚析構関数があることを確定する
1880 ワード
条項14:ベースクラスに虚析構関数があることを確定する
この問題については、この例を直接挙げたほうが説明しやすいと思います.
ほら、DELETEの時、派生類の戦車の数は解放されなかった.解決方法は簡単で,ベースクラスの解析関数を虚関数に設定する.では、言葉の意味は、譲派に変わります.
生類は自分の行為をカスタマイズする.したがって、ベースクラスをカスタマイズする場合は、その構造関数に虚関数を指定します.
では、各ベースクラスに仮想関数を申請しますか?
仮想関数のコストが32ビットのポインタを生成することであることを明らかにすることは、移植不可能になるのではないでしょうか.
この問題については、この例を直接挙げたほうが説明しやすいと思います.
class enemytarget {
public:
enemytarget() { ++numtargets; }
enemytarget(const enemytarget&) { ++numtargets; }
~enemytarget() { --numtargets; }
static size_t numberoftargets()
{ return numtargets; }
virtual bool destroy(){return 0;}; // enemytarget
//
private:
static size_t numtargets; //
};
size_t enemytarget::numtargets=0;
class enemytank: public enemytarget {
public:
enemytank() { ++numtanks; }
enemytank(const enemytank& rhs)
: enemytarget(rhs) //
{ ++numtanks; }
~enemytank() { --numtanks; }
static size_t numberoftanks()
{ return numtanks; }
virtual bool destroy(){return 0;};
private:
static size_t numtanks; //
};
size_t enemytank::numtanks=0;
int main()
{
enemytarget *targetptr = new enemytank;
cout<<"targetptr: "<<targetptr->numberoftargets()<<endl;
cout<<"targetptr: "<<enemytank::numberoftanks()<<endl;
delete targetptr;
cout<<"targetptr: "<<targetptr->numberoftargets()<<endl;
cout<<"targetptr: "<<enemytank::numberoftanks()<<endl;
return 0;
}
:
targetptr: 1
targetptr: 1
targetptr: 0 //
targetptr: 1
Press any key to continue
ほら、DELETEの時、派生類の戦車の数は解放されなかった.解決方法は簡単で,ベースクラスの解析関数を虚関数に設定する.では、言葉の意味は、譲派に変わります.
生類は自分の行為をカスタマイズする.したがって、ベースクラスをカスタマイズする場合は、その構造関数に虚関数を指定します.
では、各ベースクラスに仮想関数を申請しますか?
仮想関数のコストが32ビットのポインタを生成することであることを明らかにすることは、移植不可能になるのではないでしょうか.