首页 > 技术知识 > 正文

一般快速初始化数组会用到mmset 或者手动一个一个赋值,今天我们来讲讲另一种方法。

这个方法是我在从海思发布的SDK包中学来的,一开始我还不明白为什么他的代码要这样子写:

static int g_fd[ISP_MAX_PIPE_NUM] = { [0 …(ISP_MAX_PIPE_NUM – 1)] = -1 };

看这行代码的时候我是毫无头绪,为此也上网查了很多资料,包括 “…” 的用法, 虽然以前在main函数接受参数的时候看过“…” 大概就是说让main函数接受可变的参数个数。但是“…”出现在这里我就搞不明白了。

因为海思的后面的代码有用到这个数组的元素,而且没有初始化数组,所以我在想这样子的写法是不是一种快速初始化的方法,为此我做了一个例程去验证我的猜想。

#include<stdio.h> #define NUM 10 int main() { int a[NUM]={[0 …(NUM – 1)] = -1}; int i =0; for(;i<10;i++) { printf(“%d”,a[i]); } return 0; }

输出结果为:-1-1-1-1-1-1-1-1-1-1

我觉得这个方法很神奇,除此之外初始化部分数组成员为不同的值也可以用这个方法。

#include<stdio.h> #define NUM 10 int main() { int a[NUM]={[0 …5] = -1,[5 … 9]=2}; int i =0; for(;i<10;i++) { printf(“%d”,a[i]); } }

输出为:-1-1-1-1-122222

转载:https://blog.csdn.net/weixin_44794688/article/details/104746882

猜你喜欢