(7)指针运算
在前几篇文章中,我们已经见过指针运算的使用场景,并多次使用指针运算来进行验证。
这里我们来特别地总结下。指针运算的本质含义。
在c语言中。如果p、pa、pb都是某种类型的指针,这种运算被称为指针运算(算术运算):
- ,前提:pa和pb类型同样。
其本质是
1.。
2.。得到的是逻辑存储单元数。而不是简单的物理字节数。
代码验证
int main(void)
{
int array[] = {1, 2, 3};
int *pa = array;
int *pb = array + 3;
printf("sizeof(pa)...%d\n", sizeof(pa));
printf("pb-pa...%d\n", pb - pa);
printf("((unsigned)pb-(unsigned)pa)/sizeof(pa)...%d\n", ((unsigned)pb - (unsigned)pa) / sizeof(pa));
return 0;
}
执行
当然,把pa-pb解释成((char*)pa-(char*)pb)/sizeof(pa)也是能够的。
指针运算总结
指针存储的是地址。地址本质是一个unsigned类型的整数,对于p+1,并非简单的把p的值往前移动一个字节。一句话:指针运算紧紧依赖于指针的类型。
所以指针运算中,清楚指针的类型是重要的。这也是为什么:能够用指针运算来測试指针类型。
另一种指针运算:关系运算。
这个纯粹是地址大小的比較,非常好理解。
必须指出,pa+pb这种运算是不存在的!
专栏文件夹: