韩国电商网站排名,网站建设的广告词,做网站的没有进项票怎么办,nodejs php wordpress目的#xff1a;
学习C模板的编写#xff0c;使用模板类包装一个可调用对象 可调用对象包括#xff1a;普通函数#xff0c; lambda表达式#xff0c; 类成员函数
可以参考到QtConcurrent::run的实现#xff0c;可以看到这个函数有非常多重载#xff0c;其中可以接受类…目的
学习C模板的编写使用模板类包装一个可调用对象 可调用对象包括普通函数 lambda表达式 类成员函数
可以参考到QtConcurrent::run的实现可以看到这个函数有非常多重载其中可以接受类成员函数的重载如下(截图仅能展示部分) 个人认为这里的实现不是很好这里是针对不同参数个数的函数每一个都做一个重载如果能实现一种方式可以适配任意类型和数量的参数就好了
class AsyncTask
{
public:AsyncTask();// 支持可调用对象template typename Functor, typename ...Argsstatic QFuturestd::result_of_tFunctor(Args...) postTask(Functor func, Args ...args){return QtConcurrent::run(std::forwardFunctor(func), std::forwardArgs(args)...);}// 支持类成员函数template typename Class, typename ReturnType, typename... Argsstatic QFutureReturnType postTask(Class* instance, ReturnType(Class::*memFunc)(Args...), Args... args){return QtConcurrent::run(instance, memFunc, std::forwardArgs(args)...);}
};使用
class A
{
public:int memFunc(double y, int x){qDebug() class member func: y x QThread::currentThreadId();return x;}
};int normalFunc(int x)
{qDebug() normal function: x QThread::currentThreadId();return x;
}int main(int argc, char *argv[])
{QFuturebool future AsyncTask::postTask([](int x, int y){qDebug() lambda: x y QThread::currentThreadId();return x y;}, 3, 2); //绑定lambda表达式QFutureint future2 AsyncTask::postTask(normalFunc, 5); //绑定普通函数A x;QFutureint future3 AsyncTask::postTask(x, A::memFunc, 2.5, 3); //绑定类成员函数}使用模板类包装类成员函数
// 模板类用于包装类成员函数指针
template typename Class, typename RetType, typename ...Args
class MemberFunctionPointer
{
public:using MemFuncPtr RetType(Class::*)(Args...); //类成员函数指针MemberFunctionPointer(MemFuncPtr ptr, Class* obj): m_ptr(ptr), object(obj){}RetType invoke(Args... args){return (object-*m_ptr)(std:: forwardArgs(args)...);}
private:MemFuncPtr m_ptr;Class* object;
};// 辅助函数用于模板参数推导
// C17之前, 模板类的模板参数不能自动推导,必须显示指出, 例如std::vectorint; std::listint; 而模板函数的模板参数可以自动推导, 所以标准库才提供 std::make_pair的函数,减轻模板类的编码负担
template typename Class, typename RetType, typename... Args
MemberFunctionPointerClass, RetType, Args... make_wrapper(RetType (Class::*fn)(Args...), Class* object)
{return MemberFunctionPointerClass, RetType, Args...(fn, object);
}使用 auto wrapper make_wrapper(A::memFunc, x);wrapper.invoke(3.2, 8);参考