幾乎在每本課本中幾乎都是這樣寫的,當一個類實例化以後,必將執行構造函數,那麼在該類被釋放的時候,必將執行析構函數。似乎在人們的印象裡,構造函數與析構函數如同一對雙胞胎一樣,執行完構造函數,必將會執行析構函數......
今天我做了個實驗,徹底的推翻了這個理論。代碼如下:
#include "stdafx.h"
using namespace std;
class mycs
{
public:
mycs()
{
cout<<"構造函數"<<endl;
exit(1);
}
~mycs()
{
cout<<"析構函數"<<endl;
}
};
mycs cs;
int _tmain(int argc, _TCHAR* argv[])
{
return 0;
}
在構造函數中執行了EXIT函數,那麼必然不執行析構函數。但是這個EXIT放在其他地方,析構函數是會執行的。我猜理由如下:
因為EXIT的優先級比析構函數的優先級高,EXIT執行完以後,自動把權限返回給了OS......就這樣......