在 C 中,当使用 lambda 作为参数调用函数时,如果有多个重载与lambda 的类型。这可能会导致编译错误。
考虑以下代码:
#include <functional> void foo(std::function<void()> f) { f(); } void foo(void (*f)()) { f(); } int main() { foo([](){}); // ambiguous }
在此代码中,有两个 foo 重载:一个采用 std::function
要解决此歧义,可以在lambda,如下所示:
foo(+[](){}); // not ambiguous (calls the function pointer overload)
加号运算符强制将 lambda 转换为函数指针,使得 foo 的第二次重载能够精确匹配并无歧义地调用。
此行为源于一元加运算符将某些类型(包括 lambda)转换为函数指针的能力。该转换函数定义如下:
The operand of the unary + operator shall have arithmetic, unscoped enumeration, or pointer type, and the result is the value of the argument.
由于 lambda 的闭包类型具有到函数指针的转换函数,因此一元加运算符将 lambda 转换为所需的函数指针类型,从而允许精确匹配重载解析。
以上是在 C 中将 Lambda 作为参数传递时如何解决重载函数中的歧义?的详细内容。更多信息请关注PHP中文网其他相关文章!