为什么要动态分配内存
在C++程序中,所有内存需求都是在程序执行之前通过定义所需的变量来确定的。 但是可能存在程序的内存需求只能在运行时确定的情况。 例如,当需要的内存取决于用户输入。 在这些情况下,程序需要动态分配内存,C ++语言将运算符new和delete合成在一起来解决动态分配内存问题.
1. new和delete的基本用法
1.1 变量申请
int* pointer = new int;
//...
delete pointer;
1.2 数组申请
int * foo;
foo = new int [5];
delete[] foo;
1.3 类对象申请
class A {...} //声明一个类 A
A *obj = new A(); //使用 new 创建对象
delete obj; // 调用析构函数
2. new和mallc()的区别
new关键字是C++的一部分, 而malloc是C库提供的函数;
当new在堆上动态分配一个对象时, 他实际做了三件事: 获得一块内存空间(这一步调用了mallc()函数), 调用构造函数, 返回正确的指针. 所以new调用了对象的构造函数, 而malloc()没有.
同理使用delete的时候也是先调用类的析构函数, 然后再释放内存空间.
3. 内存分配错误
3.1 直接返回异常
int main()
{
int* foo;
foo = new int [10000000000];
return 0;
}
输出:
error:
terminate called after throwing an instance of 'std::bad_alloc'
what(): std::bad_alloc
Aborted (core dumped)
3.2 使用nothrow,返回空指针
#include<iostream>
int main()
{
int * foo;
foo = new (std::nothrow) int [10000000000];
if (foo == NULL)
{
std::cout<< "allocate error."<<std::endl;// error assigning memory. Take measures.
}
return 0;
}
输出:
allocate error.
参考资料:
【C++】动态内存分配详解(new/new[]和delete/delete[])
深入C++的new
C++ new的三种用法详细解析
C++ new 的用法 (总结)
C++ 工程实践(2):不要重载全局 ::operator new()