【C语言经典面试题】求数组元素的个数的宏定义

描述

【C语言经典面试题】求数组元素的个数的宏定义

经典面试题,有必要了解下!

1 问题描述

在C语言中,如何求一个数组中元素的个数呢?想想看!

2 示例代码

为此,我简单写一段示例代码:

#include 
#include #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])int test_array[] = {1, 2, 3, 4, 5, 6};
​
int main(int argc, const char *argv[])
{
printf("cnt: %d\\\\\\\\n", ARRAY_SIZE(test_array));
return 0;
}

重点语句就是: #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])

3 总结

分析一下上面的宏定义:

先用sizeof数组求出整个数组所占的内存大小 a;

其次用sizeof求出单个数组元素所占的内存大小 b;

最后利用数组四线性存储的特性,使用除法,用 a 除以 b,即可求出数组中元素的个数。

我们来看一下测试结果:

C语言

这个与数据定义中的6个元素是保持一致的。

C语言

4 更多分享

[架构师李肯]

架构师李肯全网同名 ),一个专注于嵌入式IoT领域的架构师。有着近10年的嵌入式一线开发经验,深耕IoT领域多年,熟知IoT领域的业务发展,深度掌握IoT领域的相关技术栈,包括但不限于主流RTOS内核的实现及其移植、硬件驱动移植开发、网络通讯协议开发、编译构建原理及其实现、底层汇编及编译原理、编译优化及代码重构、主流IoT云平台的对接、嵌入式IoT系统的架构设计等等。拥有多项IoT领域的发明专利,热衷于技术分享,有多年撰写技术博客的经验积累,坚信【知识改变命运,技术改变世界】!

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分