假设我有这段代码:
// These struct should never be modified after the fact.
typedef struct keyvalue {
const char *identifier;
const void *udObj;
} keyvalue;
typedef struct my_object {
const char *name;
const keyvalue *kv;
} my_object;
// Later, I want to use it as follows... (no workies)
const my_object mo = {
.name = "Stigma",
.kv = {
{ "test", test },
{ "test2", test2 },
{ NULL, NULL }
}
};
// I also want to support syntax like: (no workies, either)
const key_value custom_kv[] = {
{ "test", test },
{ NULL, NULL }
};
const my_object mo = {
.name = "Stigma",
.kv = custom_kv
};
遗憾的是,我似乎无法让它发挥作用。编译之前的g++报错如下:
error: invalid initializer for ‘const keyvalue my_object::kv [0]’
辅助节点收到类似的模糊错误消息:
error: too many initializers for ‘const key_value [0]
我试过为 *kv 添加另一层指针,但老实说我不认为这是我应该走的路:那是绝望的开始。我有点想撕掉const 说明符,但那将是失败的!
我如何正确声明我的结构和结构初始化以获得我正在寻找的功能/意义?最好不要在此过程中复制整个数组,因为那样会很恶心。
(是的,我知道这是 C 风格的代码,我有一个 C++ 标记。这个代码库非常困惑,用 g++ 编译但仍然想坚持 C 模式,因为一些愚蠢的原因无关紧要对于这个问题。情况就是这样,我无力改变。)
最佳答案
第一种方法的问题是您不能将数组的初始值设定项分配给指针。您可以将其转换为模板以使用不同大小的数组。但是你的第二个例子会遇到一些问题。我以某种方式为您提供了解决方案。这个怎么样:
typedef struct keyvalue {
const char *identifier;
const void *udObj;
} keyvalue;
template<int size>
struct my_object {
const char *name;
const struct keyvalue kv[size];
};
// You Need to define the size of the inner array
const my_object<3> mo = {
.name = "Stigma",
.kv = {
{ "test", test},
{ "test2", test2},
{ NULL, NULL }
}
};
const struct keyvalue custom_kv[] = {
{ "test", test},
{ NULL, NULL }
};
// Here you Need to use the initializer list as follows. There is no way around
const my_object<2> mo2 = {
.name = "Stigma",
.kv = {
{ custom_kv[0].identifier, custom_kv[0].udObj },
{ custom_kv[1].identifier, custom_kv[1].udObj }
}
};
关于c++ - 如何拥有灵活的嵌套初始化器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30871045/