C++提供了一种“动态内存分配”机制,使得程序可以在运行期间,根据实际需求,要求操作系统临时分配一片内存空间用于存放数据;通过new运算符来实现;
new实现变量和一维指针:
int * P; //定义了指针变量,但未指定指向的位置
P = new int; //开辟一个存放整数的空间,并返回一个存储空间的地址(即指针);
* P = 5; //给指针指向的空间存值;
int * P = new int(5); //与上相等
分配一个任意大小的数组:
T * P;
P = new T[N]; //T是任意类类型名, N代表元素个数
int* p = new int[5]{0 ,5 ,6 ,3 ,4};; //开辟一个存放5个整数(数组)的空间,并进行赋值返回首元素的地址
cout << *(p + 2) << endl; //对
二维数组: (以5行5列的矩阵为列)
方法1:
1 int i;
2 int row = 5,list = 5;
3 int **Matrix;
4 Matrix = new int *[row]; //给一维指针开辟空间
6 for(i = 0;i<row;i++)
7 Matrix[i] = new int [list]; //第二维空间开辟
方法2
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;
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 delete [] Matrix;
发现错误,修改了一下,贴一个正确的二维数组的例子;
1 #include<iostream>
2
3 using namespace std;
4
5 int main()
6 {
7 int i,j;
8 int row = 5,list = 5;
9 int **Matrix;
10 Matrix = new int *[row];
11 for(i = 0;i<row;i++)
12 {
13 Matrix[i] = new int [list];
14 for(j = 0;j<list;j++)
15 Matrix[i][j] = 1;
16 }
17 for(i = 0;i<row;i++)
18 {
19 for(j = 0;j<list;j++)
20 cout<<Matrix[i][j]<<" ";
21 cout<<endl;
22 }
23 for(i = 0;i<row;i++)
24 delete [] Matrix[i];
25 delete [] Matrix;
26 return 0;
27 }