大家好,又见面了,我是你们的朋友全栈君。
通常定义变量(或对象),编译器在编译时可以根据该变量(或对象)的类型知道所需内存空间的大小,从而系统在适当的时候事先为他们分配确定的存储空间。这种内存分配称为静态存储分配; 这种内存分配的方法存在比较严重的缺陷。
在使用数组的时候(线性拟合),总有一个问题困扰着我们:数组应该有多大?在很多的情况下,你并不能事先确定数组的大小。
C/C++定义了4个内存区间:代码区,全局变量与静态变量区,局部变量区即栈区(stack),动态存储区,(堆heap区或自由存储区free store)。 动态内存分配技术可以保证 程序在运行过程中,按照实际需要申请适量的内存,使用结束后还可以释放; 这种在程序运行过程中申请和释放的的存储单元也称为堆对象,申请和释放的过程一般称为建立(New)和删除(delete)。 所有动态存储分配都在堆区中进行。
功能:在程序执行期间,申请用于存放T类型对象的内存空间,并依初值列表赋以初值。 结果
**功能:**释放指针p所指向的内存。 p必须是new操作的返回值。
int *point;
point=new int(2);
C++比C中多了类的概念, 建立对象时,要调用类的构造函数; 删除对象时,要调用类的析构函数。
下例中delete p; 是错误的 ,要用delete []p才行
int * p = new int[88];
delete p; //这里就内存泄露了,要用delete []p才行
int function(int num)
{
int *p = new[44];
if( num > 111)
return 0;
delete []p;
return 1;
}
分配:new 类型名T [数组长度 ] 数组长度可以是任何表达式,在运行时计算 释放:delete [] 数组名p 释放指针p所指向的数组。 p必须是用new分配得到的数组首地址。
new 类型名T[第1维长度][第2维长度]…; 如果内存申请成功,new运算返回一个指向新分配内存首地址的指针,是一个T类型的数组,数组元素的个数为除最左边一维外各维下标表达式的乘积。
错误示例: 例如:动态创建一个2行3列的动态数组:
char *fp;
fp = new char[2][3];
正确实例:
char (*fp)[3];
fp = new char[2][3];
动态生成二维数组还可以这样子
int **a = new int*[n];
for(int i = 0; i < n; i++)
a[i] = new int[m];
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/170923.html原文链接:https://javaforall.cn