我正在分配std::function<double()>
一个lambda表达式。这段代码
if(fn_type==exponential)
k.*variable = [=,&k](){ return initial*exp(-k.kstep*par); };
else
k.*variable = [=,&k](){ return initial*pow(k.kstep, par); };
而如果我想使用三元运算符
k.*variable = (fn_type==exponential ? [=,&k](){ return initial*exp(-k.kstep*par); } : [=,&k](){ return initial*pow(k.kstep, par); });
我收到以下错误:
error: no match for ternary ‘operator?:’ in <awfully long template error, because this whole thing is in a class defined in a function...>
这是一个gcc bug(我使用的是4.7.2)?否则为什么标准中有这个限制?
答案 0 :(得分:19)
条件运算符的第二个和第三个操作数必须具有相同的类型,或者必须有一些公共类型,它们都可以转换为编译器可以解决的类型。编译器只会考虑少数转换。
您的两个lambda表达式具有不同的类型,并且没有可以转换它们的常见类型(转换为用户定义的类型,如std::function<double()>
,因为可能存在无限数量的有效的目标类型)。
您可以直接将每个操作数转换为std::function<double()>
:
k.*variable = fn_type==exponential
? std::function<double()>([=,&k](){ return initial*exp(-k.kstep*par); })
: std::function<double()>([=,&k](){ return initial*pow(k.kstep, par); });
但实际上,使用if
/ else
更清晰。
答案 1 :(得分:-1)
也面临此问题-无法编译!
'if / else'对我不好,我想打开自动类型推断功能。
auto memcpy_traits = [&](uint8_t* line_dst, const uint8_t* curr_src, const size_t bytes_to_copy) { std::memcpy(line_dst, curr_src, bytes_to_copy); line_dst += bytes_to_copy; curr_src += bytes_to_copy; } : [&](uint8_t* line_dst, const uint8_t* curr_src, const size_t bytes_to_copy) { std::memcpy(line_dst, curr_src, bytes_to_copy); line_dst += bytes_to_copy; curr_src += bytes_to_copy; };