1.动态分配内存的概述
在数组一章中,介绍过数组的长度是预先定义好的,在整个程序中固定不变,但是在实际的编程中,往往会发生这种情况,即所需的内存空间取决于实际输入的数据,而无法预先确定 。为了解决上述问
题,C
++
语言提供了一些关键字,可以按需要动态的分配内存空间,也可把不再使用的空间回收再次利用。C语言中用
malloc/free . . .; C++里用new/delete;
2. 内存分区
进程:可执行文件 从运行到结束 整个动态的过程 就叫进程。(占内存空间)
在
32
位平台
每一个进程 占
4G
空间(虚拟空间)
3. 静态分配、动态分配
3.1 静态分配
1
、在程序编译或运行过程中,按事先规定大小分配内存空间的分配方式。
int a [5]
;
2
、必须事先知道所需空间的大小。
3
、分配在栈区或全局变量区,一般以数组的形式
3.2 动态分配
1
、在程序运行过程中,根据需要大小自由分配所需空间。
2
、按需分配。
3
、分配在堆区,一般使用特定的关键字进行分配
4. new和delete
4.1 new和delete操作基本类型空间
new申请堆区空间
delete
释放空间
申请int型空间,首先就要定义一个int型指针;从堆区申请这个空间,你要用指针去指向这个空间。释放空间 只需要给空间起始地址就行了,new和delete是成对出现的;如果没有delete的话,只要进程不结束,那么这个堆区空间一直存在,不太安全;
int * p = NULL ;p = new int ; // 从堆区申请 int 类型大小的空间* p = 10 ;cout << "*p=" <<* p << endl ; //10// 释放空间delete p ;
//new 申请空间的同时 初始化空间内容int * p1 = NULL ;p1 = new int ( 10 ); //用小括号,数组初始化用大括号cout << "*p=" <<* p << endl ; //10delete p1 ;
4.2 new和delete操作数组空间
new与[]结合表示申请数组空间 delete释放的时候也需要[]
#include<iostream>
using namespace std;
int main()
{
int *arr = NULL;
arr = new int[5]{ 1,2,3,4,5 };
int i = 0;
for (i = 0; i < 5; i++)
{
cout << arr[i] << " ";
}
cout << endl;delete [ ] arr; //如果new有[ ],delete也要有 [ ]
return 0;
}