c++中类和对象_对象的动态申请

c中的动态申请:用malloc、free动态申请、释放内存不会调用构造函数和析构函数(一般c++中不能使用他们来动态申请和释放内存)

c++中的动态申请、释放: 申请:类型 * p=new 类型; delete  p; (数组: 类型 * p=new 类型[];   delete []p;)

delete void *问题:直接释放void *类型不会调用析构函数,需要强制成对应类型

new delete采用相同形式:new 一个单一对象时 delete 一个单一对象 new 一个数组时 delete 一个数组

#include <iostream>

#include <string.h>

#include <stdlib.h>

using namespace std;

class person{

public : 

person(){ cout <<"无参构造"<<endl;}

person(int a){

age =a;

cout<<"有参构造"<<endl;}

~person(){cout<<"析构函数"<<endl;}

int age; 

};

void test01(){

person * p1=(person *)malloc(sizeof(person));
free(p1);

}

void test02(){

person * p1=new person;  //用new关键字调用了析构函数并完成初始化

delete p1;  //用delete关键字调用析构函数完成释放

}

void test03(){

int *p=new int[10];  //数组的动态申请与释放

delete []p;

//person *p1=new person[10](10);   //数组的动态申请不能调用有参构造  否则报错

}

void test04(){

void * p1=new person;

delete p1; //无法释放

}

int main(){

test01();  //未调用构造析构函数,无结果

test02;

return 0;

}

运行结果:无参构造

                  析构函数

                  无参构造

posted @   spking  阅读(153)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示