指针可以加上或减去一个整数。指针的这种运算的意义和通常的数值的加减运算的意义是不一样的。例如 :
例二:
1、chara[20];
2、int*ptr=a;
...
...
3、ptr++;
在上例中,指针 ptr 的类型是 int*,它指向的类型是 int,它被初始化为指向整形变量 a。接下来的第
3 句中,指针 ptr 被加了 1,编译器是这样处理的:它把指针 ptr 的值加上了 sizeof(int),在 32 位程序
中,是被加上了 4。由于地址是用字节做单位的,故 ptr 所指向的地址由原来的变量 a 的地址向高地址方
向增加了 4 个字节。
由于 char 类型的长度是一个字节,所以,原来 ptr 是指向数组 a 的第 0 号单元开始的四个字节,此时指
向了数组 a 中从第 4 号单元开始的四个字节。
我们可以用一个指针和一个循环来遍历一个数组,看例子:
例三:
intarray[20];
int*ptr=array;
...
//此处略去为整型数组赋值的代码。
...
for(i=0;i <20;i++)
{
(*ptr)++;
ptr++;
}
这个例子将整型数组中各个单元的值加 1。由于每次循环都将指针 ptr 加 1,所以每次循环都能访问
数组的下一个单元。
再看例子:
例四:
1、chara[20];
2、int*ptr=a;
...
...
3、ptr+=5;
在这个例子中,ptr 被加上了 5,编译器是这样处理的:将指针 ptr 的值加上 5 乘 sizeof(int),在 32
位程序中就是加上了 5 乘 4=20。由于地址的单位是字节,故现在的 ptr 所指向的地址比起加 5 后的 ptr
所指向的地址来说,向高地址方向移动了 20 个字节。在这个例子中,没加 5 前的 ptr 指向数组 a 的第 0
号单元开始的四个字节,加 5 后,ptr 已经指向了数组 a 的合法范围之外了。虽然这种情况在应用上会出
问题,但在语法上却是可以的。这也体现出了指针的灵活性。
如果上例中,ptr 是被减去 5,那么处理过程大同小异,只不过 ptr 的值是被减去 5 乘 sizeof(int),新的
ptr 指向的地址将比原来的 ptr 所指向的地址向低地址方向移动了 20 个字节。