類類型的指針初始化與內存的釋放

在刷題的時候遇到了這樣一個問題,說是一個class A{ A(){};然後在main函數中定義了A*a;問是不是調用了構造函數,答案是並沒有調用。因爲只是聲明瞭指針,並沒有實例化對象,所以並不能調用構造函數,所以需要進行實例化即 a=new A;這樣就可以調用構造函數了,因爲使用new申請的空間是在堆區,是永久存在的,所以需要人工釋放,即delete a,在釋放的同時析構函數被調用

#include<iostream>
using namespace std;
class B{


public:
B(int b)
{
a=b;
cout<<"B的構造函數"<<endl;
}
~B()
{
cout<<"b的析構函數"<<endl;
}
private:
int a;
};
class B1
{
public:
B1()
{
cout<<"B1的構造函數"<<endl;


}
~B1(){cout<<"b1的析構函數啊"<<endl;}
};
int main()
{
B *p;
B1 *p1;
p=new B(2);
p1=new B1;
delete p;
    cout<<"實驗用的p"<<endl;
    delete p1;
    cout<<"實驗用的p1"<<endl;
return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章