我正在开发一个使用 lambdas 来描述表达式术语范围的库。因为库必须分发唯一的整数来标识每个变量,所以如果库而不是用户构造变量并且用户代码将它们作为 lambda 参数接收是理想的。
(换句话说,我正在从 miniKanren 实现“call\fresh”的 C++ 模拟。)
由于用户可能希望在特定范围内引入从零到许多新变量的任何数字,我希望用户能够将具有不同数量参数的 lambdas 传递给库。但是,我不知道有任何(简单)方法(在 C++14 中)来推断任意 lambda 对象的参数数量。
我突然想到为什么不将固定数量(比如 10)的可变 id 参数传递给 lambda,并让用户代码在 lambda 中使用省略号来忽略不需要的参数?像这样的东西:
auto no_args = call_fresh([](...) { return success(); });
auto one_arg = call_fresh([](var A, ...) { return A == 1; });
auto two_args = call_fresh([](var A, var B, ...) { return A == 1 && B == 2; });
编译器资源管理器似乎接受 lambda 参数列表中的省略号,至少在 gcc 中是这样。
它会被称为这样的东西(注意代码总是传递 10 个变量 id,无论“f”是否只命名一个、两个或一个都不命名):
template <typename F>
auto call_fresh(F f)
{
return [f](StateCounter sc) {
return f(sc+0,sc+1,sc+2,sc+3,sc+4,
sc+5,sc+6,sc+7,sc+8,sc+9);
};
}
诚然这是一个令我感到惊讶的功能,有什么理由不使用带有省略号的 lambdas 吗?