如何拥有灵活的嵌套初始化器?
How to have flexible nested initializers?
假设我有这个代码:
// 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 }
}
};
假设我有这个代码:
// 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 }
}
};