本人未重视new与指针的使用,终于,终于在前一天船翻了,而且没有爬上岸;
故此,今特来补全new的用法,及其一些规则;
话不多说
c++提供了一种“动态内存分配”机制,使得程序可以在运行期间,根据实际需求,要求操作系统临时分配一片内存空间用于存放数据;
通过new运算符来实现;
new实现一维指针:
1 int * p; 2 p = new int; //开辟一个存放整数的空间,并返回一个存储空间的地址(即指针); 3 * p = 5; 4 5 int * p = new int(5); //与上相等 6 int * y = new int; 7 int * y = new int(100); //开辟一个存放整数的空间,并指定该整数的初值为100,返回一个该存储空间的地址;
分配一个任意大小的数组:
1 t * p; 2 p = new t[n]; //t是任意类类型名, n代表元素个数 3 4 int *a = new int[10]; //开辟一个存放10个整数(数组)的空间,返回首元素的地址
二维数组: (以5行5列的矩阵为列)
1 int i; 2 int row = 5,list = 5; 3 int **matrix; 4 // matrix = new int *[row]; //给一维指针开辟空间 5 * matrix = new int [row]; //给一维指针开辟空间 6 for(i = 0;i<row;i++) 7 matrix[i] = new int [list]; //第二维空间开辟 8 // *(matrix+i) = new int [list]; //第二维空间开辟
一维二维的两种方式均可使用;
1 int * matrix = new int[row * list]; //当成一维数组连续开辟
简化二维指针的开辟,通过 matrix [ i * (list + 1) + j ]来访问第i行第j列的数据;
开辟指针的释放:
1 int * p = new int; 2 * p = 5; 3 delete p; 4 5 int * p = new int [10]; 6 p[0][0] = 1; 7 delete [] p;
用new运算符动态分配的内存空间,要用delete运算符释放,否则,会出现“内存泄漏”;
上述矩阵的释放方式:
1 for(i = 0;i < row;i++) 2 delete [] matrix[i]; 3 delete [] matrix; 4 5 // 6 // 7 delete [] matrix;
2019-11-02 16:56:02
下次学到再来;
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/c-cdevelopment/601163.html