C++动态分配内存(new和delete方法)

为什么要动态分配内存

在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

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()

你可能感兴趣的:(c++,c++,new,delete)