指针与数组
数组的元素在内存中是互连的,通过指针操作数组某个元素
方法1
int vals[4]={1,2,3,4};
int* p=vals;
/*p指向数组的内存地址,即第一个元素的地址*/
printf(“%d”,*p);
/*输出p地址的值*/
p+=1;
/* p向后移动一个内存地址*/
printf(“%d”,*p);
/*输出当前p地址的值*/
printf(“%d”,*(vals+2));
/*直接输出数组第三个元素内存地址的值*/
/*赋值*/
*p=5;
/* 给当前p地址赋值*/
注:数组名即是一个内存地址,等同于第一个元素的地址。*后面如果跟内存地址,即可以获得该内存地址的值
方法2
int vals[4]={1,2,3,4};
int* p=vals;
printf(“%d”,p[0]);
printf(“%d”,p[1]);
/*赋值*/
p[0]=5;
/* 给p[0]的地址赋值*/
注:当一个指针指向数组时,这个指针也是一个数组,p[0]即所指向数组的第一个元素的值,同样也不能出界。
小案例
int vals[4]={1,2,3,4};
for(int* p=vals;p<vals+4;p++){
printf("%d\n",*p);
}
空指针
例如int* p=0
; p就是一个空指针
判断是否为空指针
if(p){
...
}