由之前指针介绍所述,指针中保存的是地址。所以指针的运算则是地址之间的变更或称之为指针的移动(不支持乘除,地址的乘除毫无意义)。然而,具体的变更数值要根据类型来确定。因为在C语言中类型决定了占用的空间。
比如:
- 指针的加法:
#includeint main(void){ char a[] = {1,2,3,4,5}; char *p = a; printf("%pn",p); printf("%pn",p+1); int b[] = {1,2,3,4,5}; int *q = b; printf("%pn",q); printf("%pn",q+1); }
由输出的地址可看出(具体的输出就不展示了,大家自己动动手),不同的类型指针移动的距离有所不同(往后移动了一个sizeof,指针与指针之间的加法同理,但是要注意类型),char为1,int为4。在大于一个字节的类型进行加法时,切记不可在地址上+1,因为数组中地址是连续的块,比如int是4个4个的字节组成,若是只加一个字节,这个地址的取值会毫无意义。
- 指针的减法:
减法同理,往前移动所减的sizeof位数,然而指针与指针相减时,输出的值为两指针之间可存放该类型的数据的个数(俩地址相减/sizeof)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)