一、赋值运算
1、把一个指针变量的值赋给指向相同类型变量的另一个指针变量。如:
int x,*ptr_x,*ptr_y;
ptr_x=&x;
ptr_y = ptr_x;
指针 ptr_x 的值为变量 x 的地址。赋值语句将指针 ptr_x 的值赋给指针 ptr_y ,现在指针 ptr_x 和指针 ptr_y 指向同一个变量 x。
2、把数组的首地址赋给指针变量。如:
int a[5],*pa;
pa=a;
由于数组元素占用内存中一块连续的存储单元,数组名就表示数组的首地址,所以可以将数组名直接赋给一个指向数组的指针变量 pa。注意,在赋值语句的数组名 a 前面不用取址符&。
二、算术运算
数值变量可以进行加减乘除算术运算。而对于指针变量,由于它保存的一个内存地址,那么可以想象,对两个指针进行乘除运算是没有意义的。那么指针的算术就主要是指指针的移动。即通过指针递增、递减、加上或者减去某个整数值来移动指针指向的内存位置。
1、使用递增/递减运算符(++和--)将指针递增或递减。如:
int *ptrnum,arr_num[10];
ptrnum = arr_num;
ptrnum++;
其中,指针 ptrnum 指向整型数组 arr_num ,即存储数组中第一个元素的地址。然后,使用++ 运算符递增该指针。这意味着, ptrnum 此时指向 arr_num[0] 地址之后的下一个连续地址,即数组中下一个元素的地址。应该注意,数组指针变量向前或者向后移动一个位置和地址加 1 或减 1 在概念上是不同的。指针变量加1,即向后移动1个位置表示指针变量指向下一个元素的首地址。而不是在原地址基础上加1。所以,一个类型为 T 的指针的移动,以 sizeof(T)为移动各单位。
2、将指针加上或者减去某个整数值。当指针加上或者减去某个整数值时,指针向前或者向后移动 n 个数据单元。如:
ptrnum = &arr_num[5];
ptrnum = ptrnum - 2;
此处指针首先指向数组的第六个元素,然后将指针减去2。这意味着 ptrnum 此时指向数组的第四个元素,即 arr_num[3]。
三、关系运算
两个指针在有意义的情况下,可以做比较运算。如可以比较两个指针,看它们是否相等,即这两个指针是否指向同一个变量。如:
#include <stdio.h>
void main()
{
int *ptrnum1, *ptrnum2;
int value = 1;
ptrnum1 = &value;
value += 10;
ptrnum2 = &value;
if (ptrnum1 == ptrnum2)
printf ("/n 两个指针指向同一个地址/n");
else
printf("/n 两个指针指向不同的地址/n");
}
其中,声明了两个指针变量 ptrnum1 和 ptrnum2。另外还声明了一个int类型的变量value,初始值为1。接着将变量value的地址赋给指针 ptrnum1中。然后将value加10,再将value的地址赋给指针ptrnum2中。通过if语句判断 ptrnum1和ptrnum2是否相等,即判断它们是否指向同一个地址。由于指针ptrnum1和ptrnum2存储的都是变量value的地址,因此即使变量value的值增加了10,地址也仍保持不变,因此相等条件的值为真,输出结果为“两个指针指向同一个地址”。