当前位置:首页 > 公众号精选 > 大鱼机器人
[导读]问题 两个数组元素的地址相减得到什么? 我们先看一段代码: #include int main(void) { int a[]={0,1,2,3,4,5}; printf("&a[0] = %d, &a[2] = %d\n", &a[0], &a[2]); return 0; } 这段代码以十进制

问题

两个数组元素的地址相减得到什么?

我们先看一段代码:

   
  1. #include <stdio.h>



  2. int main(void)

  3. {

  4. int a[]={0,1,2,3,4,5};

  5. printf("&a[0] = %d, &a[2] = %d\n", &a[0], &a[2]);

  6. return 0;

  7. }

这段代码以十进制的形式打印出第0号元素的地址和第2号元素的地址,输出结果为:

   
  1. &a[0] = 2686760, &a[2] = 2686768

所以, &a[2]-&a[0]的结果是8?但是,事实不是这样的!!让我们把其结果打印出来:

竟然是 2!我们把 &a[5]-&a[2]的结果输出来看看有什么规律:

陷阱

事实证明,两个数组元素的地址相减,其值并不是等于两个地址数值上的差,而是等于这两个地址之间内存单元的个数。本例中数组的类型是 int 类型,并且在 32bit 编译环境下编译,因此这里的内存单元的大小是4字节。所以本例中 &a[2]-&a[0]的值为:

   
  1. (2686768 - 2686760)/4

当然,若是低号元素地址减去高号元素地址,得到的结果是负数:

网上看到了一篇博客也是印证了这一点:

   
  1. https://blog.csdn.net/harvic880925/article/details/8953854

这是个很容易出错的问题,需要特别注意!

学以致用

我们的C语言每日一练(004)中的题目是

寻找数组元素第一次出现的位置

之前已经提供了两种方法,函数的返回值都是要寻找的元素的下标。这里可以稍微修改一下得到第三种方法,我们的第三种方法返回的是寻找的元素的指针:

   
  1. // 函数返回找到元素的指针

  2. int *serch(int *arr,// 已知数表的首元指针

  3. int n, // 数表中元素个数

  4. int key) // 要寻找的值

  5. {

  6. int *p;

  7. for (p = arr; p < arr+n; p++)

  8. {

  9. if (*p == key)

  10. {

  11. return p; // 返回找到元素的指针

  12. }

  13. }

  14. return NULL; // 未查找到key

  15. }

完整的验证代码为

   
  1. /*******************************************************************************************************

  2. ** 题 目: 同一个数组中两个元素的地址相减

  3. ********************************************************************************************************/

  4. #include <stdio.h>



  5. // 函数返回找到元素的指针

  6. int *serch(int *arr,// 已知数表的首元指针

  7. int n, // 数表中元素个数

  8. int key) // 要寻找的值

  9. {

  10. int *p;

  11. for (p = arr; p < arr+n; p++)

  12. {

  13. if (*p == key)

  14. {

  15. return p; // 返回找到元素的指针

  16. }

  17. }

  18. return NULL; // 未查找到key

  19. }


  20. // 定义一个全局数组

  21. int a[]={5,2,0,13,14,999,666, 55, 66, 88, 1, 5, 9};


  22. // 主函数

  23. int main(void)

  24. {

  25. int i, key;

  26. int *p_a;


  27. printf("The elements of array a is:\n");

  28. for (i = 0; i < sizeof(a)/sizeof(a[0]); i++)

  29. {

  30. printf(" %d",a[i]);

  31. }

  32. puts("\nPlease input the key number you want to search:");

  33. scanf("%d", &key);

  34. p_a = serch(a, sizeof(a)/sizeof(a[0]), key);

  35. printf("\nThe index of the key number %d in the array is: %d.", key, p_a-a);


  36. return 0;

  37. }


运行结果:

可见,得到的结果与我们C语言每日一练(004)中的验证结果一样。

-END-

猜你喜欢

机器人是如何群居生活的?<<戳这里
论嵌入式与单片机,相爱相杀。<<戳这里
做技术的,聊聊研发。 <<戳这里

 最 后   
 

若觉得文章不错,转发分享,也是我们继续更新的动力。
5T资源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、单片机、等等
在公众号内回复「 更多资源 」,即可免费获取,期待你的关注~
长按识别图中二维码关注 

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭