本人未重视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];        //给一维指针开辟空间 
6     for(i = 0;i<row;i++)
7         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

下次学到再来;

 

发现错误,修改了一下,贴一个正确的二维数组的例子;

 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 } 

2020-01-11

posted on 2019-11-02 16:56  夜_归_人  阅读(15170)  评论(0编辑  收藏  举报