标签:语法 数组类 如何 没有 amp round 总结 ack 问题
从内存角度理解指针访问数组的实质
(1)数组的特点就是:数组中各个元素的地址是依次相连的,而且数组还有一个很大的特点(其实也是数组的一个限制)就是数组中各个元素的类型必须相同。类型相同就决定了每个数组元占几个字节是相同的(譬如int数组每个元素都占4字节,没有例外)。
(2)数组中的元素其实就是地址相连接、占地大小相同的一串内存空间。这两个特点就决定了只要知道数组中一个元素的地址,就可以很容易推算出具他元素的地址。
(2)&a、a、&a[0] 从数值上来看是完全相等的,但是意义来看就不同了。从意义上来看,a和&a[0]是数组首元素首地址,而&a是整个数组的首地址;从类型来看,a和&a[0]是元素的指针,也就是int *类型,而&a是数组指针,是int (*) [5] ;类型。
总结:指针类型决定了指针如何参与运算
(1)指针参与运算时,因为指针变量本身存储的数值是表示地址的,所以运算也是地址的运算。
(2)指针参与运算的特点是,指针变量+1, 并不是真的加1,而是加1*sizeof (指针类型);如果是int *指针,则+1就实际表示地址+4,如果是char *指针,则+1就表示地址+1;如果是double*指针,则+1就表示地址+8.
(2)指针变量+1时实际不是加1而是加1*sizeof (指针类型),主要原因是希望指针+1后刚好指向下一个元素(而不希望错位)。
标签:语法 数组类 如何 没有 amp round 总结 ack 问题
原文地址:https://www.cnblogs.com/sanshijvshi/p/10284658.html