从根本上看,指针(pointer)是一个值为内存地址的变量(或数据对象),正如char类型变量的的值是字符,int类型变量的值是整数,指针变量的值是地址。那么作为一个有值的变量就一定有运算,今天我们就来揭开指针运算规则的面纱。
指针±正整数
我们的系统中,地址按字节编址,int类型占2字节,double类型占8字节。在C中,指针加1指的是增加一个存储单元。
对数组而言,加一意味着地址是下一个元素的地址。所以数组的表示法也是在变相地使用指针,单个数组名指的就是该数组的首地址。
指针-指针
可以计算两个指针的差值。通常,求差的两个指针分别指向同一个数组的不同元素,通过计算求出两元素之间的距离。差值的单位与数组类型的单位相同。
我们可以用如下的程序来帮助理解以上的指针运算法则。
#include <stdio.h>
int main() {
int a[5] = {1,2,3,4,5};
int *p1,*p2,*p3,*p4;
p1 = a; //将数组首地址赋给指针
p2 = &a[2]; //将数组中第三个元素的地址赋给指针
//指针加正整数
p3 = p1 + 4;
printf("p1 = %p , p3 = %p , *p3 = %d\n", p1,p3,*p3);
//指针减正整数
p4 = p2 - 1;
printf("p2 = %p , p4 = %p , *p4 = %d\n", p2,p4,*p4);
//指针-指针
printf("%d\n",p3 - p4);
return 0;
}
程序运行结果如下图所示:
指针+指针
有些人可能会想了既然有指针-指针,那会不会有指针+指针呢?(其实我一开始也是这个有些人之一)
答案是指针+指针是没有意义的。
那么这到底是为什么呢?我们来思考一下,如果存在如上的p3,p4两个指针变量,两者相减是只两者所指向的数组的元素距离,那两者相加难道是数组元素距离之和,那显然没什么意义。
就拿生活中的家庭门牌号举例:“门牌号161-门牌号160=1”是指两家相差一户,那“门牌号161-门牌号160=321”难道指两家合起来有321户?显然不是。
所以指针相加是没有意义滴。
指针的关系运算(比较大小)
关系运算:< <= > >= 是有意义的。不过前提是它们都指向同一个数组中的元素。根据你所使用的操作符,比较表达式将告诉你哪个指针指向数组中更前或更后的元素。标准并未定义如果两个任意的指针进行比较会产生什么结果(一般情况下就不要用了)。