c中的指针是一个地址,它是一个数值,因此,您可以对指针执行算术运算,就像对数值一样。
为了理解指针运算,让我们考虑ptr是指向地址1000的整数指针,假设32位整数,让我们对指针-执行以下算术运算
ptr++
在上述操作之后,PTR将指向位置1004,因为每次PTR递增时,它将指向下一个整数位置,该整数是4个字节,此操作将指针移动到下一个内存位置,而不影响该内存位置的实际值。如果ptr指向地址为1000的字符,则上述操作将指向位置1001,因为下一个字符将在1001处可用。
我们更喜欢在程序中使用指针而不是数组,因为变量指针可以递增,不同于数组名称,数组名称不能递增,因为它是常量指针。
#include <stdio.h> const int MAX=3; int main () { int var[]={10, 100, 200}; int i, *ptr; /* 让我们在指针中有数组地址 */ ptr=var; for ( i=0; i < MAX; i++) { printf("Address of var[%d]=%x\n", i, ptr ); printf("Value of var[%d]=%d\n", i, *ptr ); /* 移动到下一个位置 */ ptr++; } return 0; }
编译并执行上述代码时,将生成以下结果-
Address of var[0]=bf882b30 Value of var[0]=10 Address of var[1]=bf882b34 Value of var[1]=100 Address of var[2]=bf882b38 Value of var[2]=200
同样的注意事项也适用于递减指针,这会将指针的值减少其数据类型的字节数,如下所示:-
#include <stdio.h> const int MAX=3; int main () { int var[]={10, 100, 200}; int i, *ptr; /* 让我们在指针中有数组地址 */ ptr=&var[MAX-1]; for ( i=MAX; i > 0; i--) { printf("Address of var[%d]=%x\n", i-1, ptr ); printf("Value of var[%d]=%d\n", i-1, *ptr ); /* 移动到上一个位置 */ ptr--; } return 0; }
编译并执行上述代码时,将生成以下结果-
Address of var[2]=bfedbcd8 Value of var[2]=200 Address of var[1]=bfedbcd4 Value of var[1]=100 Address of var[0]=bfedbcd0 Value of var[0]=10
可以使用关系运算符(如=、<和>)比较指针。如果p1和p2指向彼此相关的变量,例如相同数组的元素,则p1和p2可以进行有意义的比较。
下面的程序通过递增变量指针来修改前面的示例-,只要它所指向的地址小于或等于数组的最后一个元素的地址,即&var[max-1]-
#include <stdio.h> const int MAX=3; int main () { int var[]={10, 100, 200}; int i, *ptr; /* 让我们有指针中第一个元素的地址 */ ptr=var; i=0; while ( ptr <= &var[MAX - 1] ) { printf("Address of var[%d]=%x\n", i, ptr ); printf("Value of var[%d]=%d\n", i, *ptr ); /* point to the next location */ ptr++; i++; } return 0; }
编译并执行上述代码时,将生成以下结果-
Address of var[0]=bfdbcb20 Value of var[0]=10 Address of var[1]=bfdbcb24 Value of var[1]=100 Address of var[2]=bfdbcb28 Value of var[2]=200
祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)