码迷,mamicode.com
首页 > 编程语言 > 详细

关于C++中的指针、数组

时间:2017-11-25 13:18:40      阅读:209      评论:0      收藏:0      [点我收藏+]

标签:round   计算   一个   字节   size   数组名   class   int   amp   

C++中指针和数组基本等价的原因在于指针算术和C++内部处理数组的方式;将整数变量加一后,其值将增加1;将指针变量加一后,增加的量等于其指向的数据类型的字节数;

指针中存储的是地址,地址在形式上和整数相似,但是意义完全不同,整数可以加减乘除,但地址相乘等操作完全没有意义;

Eg:  int *p;

     P = 0xB8000000;

上面会报类型不匹配的错误,原因在于C++不知道这是一个数字还是一个地址,所以需要先进行强制类型转换

我们常说数组名就是指针,但这么说只是为了理解,准确的说,两者还是有区别的,由于我有的地方还没有完全弄清楚,所以这里只是说说自己的看法:

数组名始终存储的是数组中第一个元素的地址,不管多少维它的类型不是指针类型,你可以认为它就是一块内存,里面存储的是地址

(1)一维的情况:

int *a;
int b = 3;
int c[3] = {1 , 2 , 3};

a = &b;
a = c;

上面这么写都是没有问题的,都是给a传入地址;但对于二维的情况就要注意了:

(2)二维的情况(二维数组在内存中也是按照一维的形式进行存储,存储结构为顺序存储):

第一种写法:

int a[2][3] = {1 , 2 , 3 , 4 , 5 , 6};
int **p;
p = a; 

上面这种写法就是错误的,错误原因是我们这里想当然的认为二维数组名a就是二级指针类型,然而这么做要么会报”非法内存的错误“,要么会报”类型不匹配“的错误,我们来分析一下:

a中存的地址是a[0][0]元素的地址,而p是一个二级指针,现在将a中存放的地址值赋给p,则p指向a[0][0]元素(即1),则*p的值就是1。则**P的值就是”地址为1“的那块内存中存放的值;这么做就会出现两种错误:

(1)如果这个地址1是计算机内部分配给系统使用的,用户没有权限,则会报”非法内存“的错误;

(2)如果这块内存用户可以使用,但是注意我在上面的”地址为1“这里打了双引号,就是说明这个”1“是int类型(或者是数组元素类型),我们之前也提过地址和整数类型只是形式相似然而意义完全不同,所以这里C++认为这个”1“是intl欸型而不是地址类型,所以就会报”类型不匹配“的错误;

综上:二维情况下,我们不能认为数组名就是二级指针;

后来,在网上看到一种说法,就是二维数组名的类型可以认为其实就是数组指针类型,操作时也没有问题,我觉得可以这么做,也可以推广到多维数组的情况:

int a[2][3] = {1 , 2 , 3 , 4 , 5 , 6};
int (*p)[3] = a;

上面这么做就没有问题,这里,p是一个数组指针类型,它指向的是一个数组,数组类型为Int,数组个数为3,起始就是二维数组第二维的元素个数(对于p,初始化的时候第一维要省略);

*(*(p + 1) + 2)的值就是a[1][2]的值,其他类似;

对于多维的情况应该也是类似,等以后如果遇到了不同点我再补充~

关于C++中的指针、数组

标签:round   计算   一个   字节   size   数组名   class   int   amp   

原文地址:http://www.cnblogs.com/zf-blog/p/7894733.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!