【C语言经典面试题】求数组元素的个数的宏定义
经典面试题,有必要了解下!
在C语言中,如何求一个数组中元素的个数呢?想想看!
为此,我简单写一段示例代码:
#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])
分析一下上面的宏定义:
先用sizeof数组求出整个数组所占的内存大小 a;
其次用sizeof求出单个数组元素所占的内存大小 b;
最后利用数组四线性存储的特性,使用除法,用 a 除以 b,即可求出数组中元素的个数。
我们来看一下测试结果:
这个与数据定义中的6个元素是保持一致的。
[架构师李肯]
架构师李肯 ( 全网同名 ),一个专注于嵌入式IoT领域的架构师。有着近10年的嵌入式一线开发经验,深耕IoT领域多年,熟知IoT领域的业务发展,深度掌握IoT领域的相关技术栈,包括但不限于主流RTOS内核的实现及其移植、硬件驱动移植开发、网络通讯协议开发、编译构建原理及其实现、底层汇编及编译原理、编译优化及代码重构、主流IoT云平台的对接、嵌入式IoT系统的架构设计等等。拥有多项IoT领域的发明专利,热衷于技术分享,有多年撰写技术博客的经验积累,坚信【知识改变命运,技术改变世界】!
全部0条评论
快来发表一下你的评论吧 !