其他分享
首页 > 其他分享> > c – 为什么在未评估的操作数内的包扩展会导致最后一个元素?

c – 为什么在未评估的操作数内的包扩展会导致最后一个元素?

作者:互联网

我可以在decltype()中执行此操作:

auto g() -> decltype(1, "", true, new int);

但不是这个:

template <class... Args>
auto g(Args&&... args) -> decltype(args...);

它失败是因为包扩展出现在decltype()中,但我认为包扩展会导致以逗号分隔的参数列表.因此,g(a,b,c)的返回类型将是decltype(c),因为逗号运算符的工作原理(它返回最后一个元素).当你在函数参数列表,模板参数列表,初始化列表等内部展开时,它可以工作.但为什么这不是这种情况?

解决方法:

参数包仅在某些情况下进行扩展.您可以通过搜索“包扩展”在标准中找到它们.例如,

A function parameter pack is a pack expansion (14.5.3).

(8.3.5 / 14).

除非在特定上下文中发生包扩展的某处明确指定,否则它不会发生,并且通常被语法禁止(即,语法上不正确).例如,decltype需要表达式作为其操作数. 1,“”,true,new int确实是一个表达式(是逗号运算符),但是args …不是表达式.但是,args …是表达式列表,因此它可以用于例如函数调用中.

标签:c,c11,templates,variadic-templates,comma-operator
来源: https://codeday.me/bug/20190722/1505886.html