指针的运算
自增
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UsjjSzB3-1612091359644)(E:\博客\指针\指针运算\自增.png)]
-
从上面的例子中可以看出,ptr1,ptr2分别指向着两种不同的类型,但是自增的时候都是加了数组的下一个元素的位置
-
就可以得出下面的结论了
-
ptr++ 的概念是在 ptr 当前地址的基础上 ,自增 ptr 对应类型的大小,
也就是说 ptr = ptr+ 1*(sizeof(类型))
自减
- 自减跟自增差不多
指针与整数的运算
(1)指针与整数的运算
指针加减数字表示的意义是指针在数组中位置的移动;
对于整数部分而言,它代表的是一个元素,对于不同的数据类型,其数组的元素占
用的字节是不一样的,
比如指针 + 1,并不是在指针地址的基础之上加 1 个地址,而是在这个指针地址的
基础上加 1 个元素占用的字节数:
如果指针的类型是 char*,那么这个时候 1 代表 1 个字节地址;
如果指针的类型是 int*,那么这个时候 1 代表 4 个字节地址;
如果指针的类型是 float*,那么这个时候 1 代表 4 个字节地址;
如果指针的类型是 double*,那么这个时候 1 代表 8 个字节地址。
(2)通用公式:
数据类型 *p;
p + n 实际指向的地址:p 基地址 + n * sizeof(数据类型)
p - n 实际指向的地址:p 基地址 - n * sizeof(数据类型)
比如
(1)对于 int 类型,比如 p 指向 0x0061FF14,则:
p+1 实际指向的是 0x0061FF18,与 p 指向的内存地址相差 4 个字节;
p+2 实际指向的是 0x0061FF1C,与 p 指向的内存地址相差 8 个字节
(2)对于 char 类型,比如 p 指向 0x0061FF28,则:
p+1 实际指向的是 0x0061FF29,与 p 指向的内存地址相差 1 个字节;
p+1 实际指向的是 0x0061FF2A,与 p 指向的内存地址相差 2 个字节;
指针之间的加减
-
知识点:
(1)指针和指针可以做减法操作,但不适合做加法运算;
(2)指针和指针做减法适用的场合:两个指针都指向同一个数组,相减结果为两个指针之
间的元素数目,而不是两个指针之间相差的字节数。
比如:int int_array[4] = {12, 34, 56, 78};
int *p_int1 = &int_array[0];
int *p_int2 = &int_array[3];
p_int2 - p_int1 的结果为 3,即是两个之间之间的元素数目为 3 个。
如果两个指针不是指向同一个数组,它们相减就没有意义。
(3)不同类型的指针不允许相减,比如
char *p1;
int *p2;