发博记录自己学习的过程。
一、指针指向一维数组
1、定义一个指针变量
int *p;
2、指向数组的指针
int arr[3]={1,2,3};
int *p;
p=arr; //数组名就是数组的首地址,指针指向数组的首地址;
同样,也可以这样来写:
p=&arr[0]; //&arr[0]也是数组的首地址,这两种方式是等价的,如下图所示:
#include<stdio.h>
int main()
{
int arr[3]={1,2,3};
int *p;
//p=arr;
p=&arr[0];
printf("首元素是%d 地址为%p\n",*p,p);
return 0;
}
#include<stdio.h>
int main()
{
int arr[3]={1,2,3};
int *p;
p=arr;
//p=&arr[0];
printf("首元素是%d 地址为%p\n",*p,p);
return 0;
}
二、指针偏移遍历数组
在上文中我们定义了一个int型的指针变量,用它来指向数组:
p=arr;
p指向的是数组的首地址,首地址中存放的是数组的首元素,我们也定义了一个int型的数组,
int arr[3]={1,2,3};
我们知道,数组的内存空间是连续的,p指向的是数组的首地址,那么p+1指向的是偏移了四个字节的地址(int型变量为四个字节),也就是arr[1]的地址,同理p+i指向的就是arr[i]的地址,我们对它取值就得到了数组元素的值(*(p+i))。
#include<stdio.h>
int main()
{
int arr[3]={1,2,3};
int *p;
p=arr;
//p=&arr[0];
printf("0元素是%d 地址为%p\n",*p,p);
printf("1元素是%d 地址为%p\n",*(p+1),p+1);
printf("1元素是%d 地址为%p\n",*(p+2),p+2);
return 0;
}
当然,我们只是为了演示指针增量与内存空间的关系,指针遍历数组还是用循环来做:
#include<stdio.h>
int main()
{
int arr[3]={1,2,3};
int *p;
p=arr;
for(int i=0;i<3;i++){
printf("%d ",*(p+i));
}
return 0;
}
今天就写到这里了,希望大家都能学有所成吧!