【发布时间】:2016-04-02 16:13:48
【问题描述】:
请看下面的代码。在捕获 lambda 表达式的情况下,它可以正常工作和编译。虽然在使用绑定可调用表达式时,我会得到一个重载表达式表达式错误
main.cpp:13:60: error: decltype cannot resolve address of overloaded function
using FuncType = decltype(&std::decay<T>::type::operator());
如何编写代码,以便获取绑定函数的 operator() 方法的类型?绑定类型是std::_Bind<void (*(std::_Placeholder<2>, std::_Placeholder<1>))(int, int)>,我也不完全理解;我知道 void (*) (int, int) 是一种类型,它是一个指向函数的指针,它接收 int、int 并返回 void。我想我不明白语法 void *(x,y) (int,int);基本上是 x,y 部分。我假设在所有模板内容之后有一个方法 void operator()(int, int) 将得到解决, bind_f(x,y) 将调用并且我试图捕获该类型。
#include <iostream>
#include <functional>
#include <type_traits>
void tester(int x, int y) {
std::cout << " x = " << x << " y = " << y << std::endl;
}
template <typename T>
class TypeChecker;
template <typename T>
using FuncType = decltype(&std::decay<T>::type::operator());
int main() {
using namespace std::placeholders;
auto bind_f = std::bind(tester, _2, _1);
bind_f(1,2);
int y = 5;
auto lambda = [y]() {
std::cout << " y = " << y << std::endl;
};
typedef FuncType<decltype(lambda)> x1;
typedef FuncType<decltype(bind_f)> x2;
//TypeChecker<decltype(bind_f)> t2;
}
【问题讨论】:
-
绑定表达式有一个模板化的调用运算符 accepts any number and kind of arguments。非多态 lambda 具有单个非模板调用运算符。
-
请问,为什么要首先使用bind?或者这只是为了造就?我并不是说这个问题不好,不要误解,只是指出非常实用的答案是“不要使用绑定”,因为建议不要使用它来支持 lambdas(尤其是在 14 中具有通用 lambdas )。
-
这是有道理的,是的,我正在创建一些涵盖所有情况的东西,但是总的来说,我想让它不能与 bind 一起使用,我只是想有人可能会要求它与 bind 一起使用。我想知道是否有办法使 FuncType 允许两种类型,如
template <typename T, typename... Ts> using FuncType = decltype(T::operator()(std::declval<Ts>()...))(Ts...);