如何编写丢弃其参数的通用可变参数 lambda
How to write a generic variadic lambda that discards its parameters?
我想写一个lambda,它通过通用引用接受任意数量的参数并完全忽略它们。显而易见的方法是使用可变参数通用参数包的语法并省略参数名称:
auto my_lambda = [](auto&&...) { return 42; };
这工作正常(使用 gcc 4.9.2),直到我尝试传递一个不可复制的对象:
struct S { S() {} S(S const&) {} };
my_lambda("meow", 42, S{});
^ error: cannot pass objects of non-trivially-copyable type 'struct S' through '...'
这是怎么回事?我的代码格式不正确,还是这是 gcc 中的错误?
无论哪种情况,最好的解决方法是什么?我发现命名参数有效,但随后我遇到了未使用的参数警告:
auto my_lambda = [](auto&&... unused) { return 42; };
^ error: unused parameter 'unused#0' [-Werror=unused-parameter]
^ error: unused parameter 'unused#1' [-Werror=unused-parameter]
^ error: unused parameter 'unused#2' [-Werror=unused-parameter]
如何禁止显示模板参数包上的未使用参数警告?
这是 GCC 中的一个解析错误(您自己报告了! auto&&...
在语法上是模棱两可的,可以解析为等价于 auto&&, ...
或参数包声明(从技术上讲,问题是...
是参数声明子句还是抽象声明器的一部分);该标准说它将被解析为后者;GCC 将其解析为前者。
命名包可解决解析歧义:
auto my_lambda = [](auto&&... unused) { return 42; };
为了抑制警告,可以应用__attribute__((__unused__))
(或者,正如丹东建议的那样,[[gnu::unused]]
@Luc):
auto my_lambda = [](auto&&... unused __attribute__((__unused__))) { return 42; };
或使用sizeof...
auto my_lambda = [](auto&&... unused) { (void) sizeof...(unused); return 42; };
相关文章:
- 在不传递参数数量且只有3个点的情况下,如何使用变差函数
- 如何使用可变参数模板强制转换每个变体类型
- 关于如何在具有单个参数的变体构造中选择替代方案?
- 调用参数排列不变函数 f(i++, i++)
- 参数归纳与标准::变体
- 模板化回调参数的逆变,如 C# 中的逆变
- 如何在没有参数包的情况下编写变差函数
- 通过具有嵌套类的工厂类获取多个变异类模板参数包
- 获取模板参数的成员变量值列表
- 保留短 lambda 用作函数的中间参数,使用 clang 格式保持不变
- 如何定义变体<x,y,z>提取模板参数的子类型
- 正确对齐内存模板,参数顺序不变
- 递归中不同参数类型的变元模板函数
- 通过函数指针传递给变差函数的参数会更改其值
- 提升预定义为带有参数的全局 lambda 的变体访问者
- 使用可变参数模板参数提升变体访问者
- boost ::变体 - 为什么模板参数比const字符串参数具有更高的优先级
- 将变参数包中的值加载到临时数组中
- 使用额外参数提升变体访客
- 正在将动态数组元素解析为参数?(变音符)