我的代码的简化版本在这里
the simplified version of my code is here
int foo(int x)
{
return x;
}
int foo(int x, int y)
{
return x+y;
}
template<typename unary_func>
int bar(int k, unary_func f)
{
return f(k);
}
int main()
{
bar(3, foo);
return 0;
}
有没有办法告诉编译器我想传递的参数是第一个‘foo’?
Is there a way to tell the compiler what I want to pass as argument is the first `foo'?
你可以给出一个明确的模板参数:
You can give an explicit template argument:
bar<int(int)>(3, foo);
或将模棱两可的函数名称强制转换为可以从中推导出模板参数的类型:
or cast the ambiguous function name to a type from which the template argument can be deduced:
bar(3, static_cast<int(*)(int)>(foo));
或将其包装在另一个函数(或函数对象)中以消除歧义
or wrap it in another function (or function object) to remove the ambiguity
bar(3, [](int x){return foo(x);});
这篇关于C++ 重载函数作为模板参数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
为什么两个函数的地址相同?Why do two functions have the same address?(为什么两个函数的地址相同?)
为什么 std::function 的初始化程序必须是可复制构Why the initializer of std::function has to be CopyConstructible?(为什么 std::function 的初始化程序必须是可复制构造的?)
混合模板与多态性mixing templates with polymorphism(混合模板与多态性)
我什么时候应该使用关键字“typename"?使用模When should I use the keyword quot;typenamequot; when using templates(我什么时候应该使用关键字“typename?使用模板时)
依赖名称解析命名空间 std/标准库Dependent name resolution amp; namespace std / Standard Library(依赖名称解析命名空间 std/标准库)
gcc 可以编译可变参数模板,而 clang 不能gcc can compile a variadic template while clang cannot(gcc 可以编译可变参数模板,而 clang 不能)