C++ 动态对象创建 对象数组

首先说说内存申请函数:

  1. malloc、calloc、realloc返回一个 void 指针,C++不允许将 void 指针赋值给其他任何指针,必须强转。
  2. malloc、calloc、realloc可能申请内存失败,所以必须根据返回值确定是否申请成功。
  3. malloc、calloc、realloc不会调用构造函数 ,free释放堆区不会调用析构函数(重要)。

C++提供了另外的申请内存空间的关键字:new

new 与 malloc函数相比,其主要的优点是, new 不只是分配了内存,它还创建了对象。

new内存分配失败时,会抛出bac_alloc异常,会返回NULL。
malloc分配内存失败时返回NULL。
使用new操作符申请内存分配时无须指定内存块的大小,编译器会根据类型信息自行计算。
malloc则需要显式地指出所需内存的尺寸。

在任何时候,某个已经动态分配内存的变量不再需要使用时,可以使用 delete 操作符释放它所占用的内存。

基本类型申请空间:
    double* pvalue  = NULL; // 初始化为 null 的指针
    pvalue  = new double;   // 为变量请求内存
释放内存:
    delete pvalue;        // 释放 pvalue 所指向的内存
为数组申请空间:
    int* arr = new int[4] {4, 5, 6, 7};    //不能初始化字符串,用strcpy
释放内存:
    delete []arr;        // 释放 pvalue 所指向的内存
为对象申请空间:
    Point* p = new Point(1, 1);  
释放内存:
    delete p;        // 释放 pvalue 所指向的内存
new 自动调用构造函数  delete 自动调用析构函数

从上述代码可以看出,使用new时指定了类型,指定的类型作为了开辟空间大小的依据。也可以看出可以在申请空间的同时初始化空间的内容。

对象数组

即元素为对象的数组。

示例:
  Point arr[2] = {Point(5, 5)};  //Point为一个类。初始的元素调用有参构造,未初始化元素调用无参构造,也就是说这个对象数组第二个元素虽然未指明,但是它是存在的,并且依据无参构造进行初始化的。
从堆区申请内存:
  Point*  arr = new Point[2] { Point(5, 5), Point(10, 3)}; //申请一个存放对象的数组空间,并初始化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值