指针的运算系列(2):指针-指针(相减)
【摘要】 指针的运算系列(2):指针-指针(相减)
指针的运算系列(2):指针-指针(相减)
对于指针,等读者在CSDN或者百度搜索到此时候,或许读者已经开始初步走向指针的中级地步了,已经对于指针有着初步的了解与认识了!
但是对于指针-指针(相减)或许大家有着些许疑惑,问什么没有指针加指针运算呢??
其实归根溯源,还是要看指针的本质!指针的本质还是地址,因此地址+地址(相加)又能得出什么来了呢??
下面笔者将用代码+解析的方法来带领大家认识一下: 指针的运算系列(2):指针-指针(相减)
#include <stdio.h>
int main()
{
int arr[10] = { 0 };
printf("%d\n", &arr[9] - &arr[0]);
printf("%d\n", &arr[0] - &arr[9]);
return 0;
}
在该段代码中,用了&(取地址操作符),通过地址来相减,其实本质还是为两个指针相减!
由于,看出来相减之后的结果,可以为正也可以为负,但所得结果的绝对值都是一样的,再结合&arr[9] - &arr[0]两者之间的距离:因此得出,指针与指针相减,得出的结果为:两者之间的距离!
但是 对于两个指针相减,需要前提:
两个指针都指向同一个数组里面(同一块连续的空间)
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)