指针的运算

指针的运算

自增

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(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;

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值