如何理解C语言的指针移动?

刚学习C语言的朋友,对指针“移动”可能不太理解。举个例子,例如下述代码:

int a = 1;

那么大家都知道整型变量a + 1肯定就是2了。如果是C语言的指针呢?例如:

int *p = 1;

指针p + 1还是2吗?

为了说明问题,请看以下C程序代码:

#include "stdio.h" 
#include "stdlib.h" 
 
int main() 
{ 
 int index = 0; 
 int number[3] = {1, 2, 3}; //定义一个整型数组 
 int *p = &number[0]; //指针p的初始值是数组第一个元素的地址 
 printf("p的值是 %x\n", p); //输出p的值,也就是数组第一个元素的地址 
 
 printf("本机int类型占用 %d 个字节\n", sizeof(int)); //得知本机上int类型占用多少字节 
 
 for(index = 0; index < 3; index++) 
 { 
 printf("第 %d 个元素的地址是 %x\n", index + 1, &number[index]); 
 }//输出数组中每一个元素的地址 
 
 for(index = 0; index < 3; index++) 
 { 
 printf("p加 %d 的值是 %x\n", index, p + index); 
 }//输出指针p+1, p+2, p+3的值 
 
 return 0; 
} 

C程序程序很简单,目的就是为了说明C语言指针p自己加上1、2、3分别得到什么值。运行结果如下:

指针p的初始值就是数组第一个元素的地址,为“12ff70”。那么从指针p + 1开始,并不是简单的12ff70 + 1 = 12ff71,而是12ff70 + 4 = 12ff74。指针p + 2也不是12ff70 + 2 = 12ff72,而是12ff70 + 4 + 4 =12ff78。所以C语言指针的增加运算与本文开头的整型变量a的增加运算还不一样,这也是许多C语言初学者经常会糊涂的一个地方。

指针p +n其实计算的是p加上n*类型占用字节数。本文指针p是int类型,本机中,使用sizeof计算出的类型int占用的字节数是4。因此,指针p + 1其实就是p + 1 * 4个字节,指针p + 2其实就是p + 2 * 4个字节。关于每种类型在本机上占用的字节数网上有很多介绍,读者可以自行搜索下。

可能也有的朋友说,这个我懂啊,p + 1其实就是往前移动了4个字节啊!但是太自大也不好,太自大的结果就是你心里知道p + 1是跨越了4个字节的地址,但是手一抖,写成了p + 4,你说这是笔误呢还是笔误呢?

举报
评论 0