指针学习四——指针、数组、地址

佐手、 提交于 2020-01-19 04:39:46

指针、数组、地址

指针是以地址作为值的变量,数组名的值是一个特殊的固定地址,看作是指针常量。

int a[100]    ,  *p;

系统把编号为3000,30002...的内存字节作为数组元素a[0],a[1]...的地址。

基地址:内存位置3000是数组a的基地址,即a[0]的地址。

地址常量:数组名a是一个地址常量。

p=a;

p=&a[0];   语句等价,都把3000这个地址值赋给了指针p。

p=a+1;

p=&a[1];

同样,也是等价的,都把3002这个地址值赋给了指针p。

指针 内存地址 内存单元 数组元素
p 3000   a[0]
p+1 3002   a[1]
p+2 3004   a[2]

 

数组元素求和:

法一:

sum=0;

for(p=a;p<=&[99];p++)

  sum+=*p;

*(a+i)与a[i]等价——地址+1为下一个地址,实际增加的不为一。

法二:

sum=0;

for(p=a;p<=&[99];p++)

  sum+=*(a+1);

法三:

p=a;

sum=0;

for(i=0;i<100;++i)

sum+=p[i];

1.数组a是指针常量,不是变量。a++是非法的。

2.变量p是指向某个指定类型的指针,p+1代表访问的是下一个变量的内存地址。p+i是有意义的。

3.若p和q都是指向数组的指针,p-q产生一个int型的值,表示之间的数组元素的个数。

4.指针每次加一减一,是加上或减去该指针所指向的那个变量数据类型的长度。

p=&a[1];

a[1]的地址是2004,p--后,p的值就是2002,所以p指向a[0]。

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!