所以我有一个结构
struct live_set_item
{
uint32_t data_0;
uint64_t data_1;
uint64_t data_2;
live_set_item(uint32_t data_0_, uint32_t data_1_, uint64_t data_2_)
: data_0(data_0_), data_1(data_1_), data_2(data_2_)
{}
};
我想用这样的初始化列表进行初始化
void foo()
{
struct live_set_item obj;
get_new_lsi(&obj);
if (failed_to_initialize(obj)) {
obj = {
.data_0 = 2000,
.data_1 = 2001,
.data_2 = 2002
};
}
}
但我不断从Clang收到此错误
test.cpp:339:21: error: no viable overloaded '='
obj = {
~~~ ^ ~
test.cpp:175:16: note: candidate function (the implicit copy assignment operator) not
viable: cannot convert initializer list argument to 'const live_set_item'
struct live_set_item
^
所以我找到了this question并尝试了
void operator=(const std::initializer_list<live_set_item>&) {}
但是现在它告诉我移动分配运算符无效?我的第一个论点是无效的吗?
test.cpp:175:16: note: candidate function (the implicit move assignment operator) not
viable: cannot convert initializer list argument to 'live_set_item'
test.cpp:204:22: note: candidate
function not viable: cannot convert argument of incomplete type 'void' to
'live_set_item' for 1st argument
void operator=(const std::initializer_list<au_live_set_item_v1>&) {}
^
这是我迷路的地方,我尝试了几种不同的方式来更改赋值运算符,以查看std :: initializer列表的cpp文档。什么都没有。有人可以告诉我我在做什么错吗?
答案 0 :(得分:0)
这不是您要在此处使用的initializer_list
;这是一个GCC designated initializer,无论您如何努力,都无法在标准C ++中使用它。
此外,您正在尝试分配,而不是初始化(尽管如果您删除.data_0 =
东西,那么复制分配就足够了。