我似乎无法仅使用简单的函数将QtConcurrent::run()
与方法(类的函数成员)关联起来。我怎样才能做到这一点?
使用常规功能,我无法发出信号和拖拽。为什么有人会发现这是QThread
的一个更好的选择,超出了我的想法并想要一些输入。
答案 0 :(得分:19)
是的,这是可能的(而且非常简单)。
以下是一个示例(来自Qt文档):
// call 'QStringList QString::split(const QString &sep, SplitBehavior behavior, Qt::CaseSensitivity cs) const' in a separate thread
QString string = ...;
QFuture<QStringList> future = QtConcurrent::run(string, &QString::split, QString(", "), QString::KeepEmptyParts, Qt::CaseSensitive);
...
QStringList result = future.result();
基本上,您所要做的就是将指向对象的指针作为第一个参数传递,将方法的地址作为第二个参数传递(后跟任何其他参数)。
答案 1 :(得分:5)
问题是当你使用指向成员函数的指针时,你还需要以某种方式提供this
参数(即应该调用成员函数的对象)。
如果您以前没有使用它,那么这个语法非常困难。阅读http://www.parashift.com/c++-faq-lite/pointers-to-members.html可能会很好。
假设您有一个班级Dog
和一个函数Dog::walkTheDog(int howlong_minutes)
。然后您应该能够使用std::bind1st
和std::mem_fun
使其适合QtConcurrent::run
:
Dog dog;
// Walk this dog for 30 minutes
QtConcurrent::run(std::bind1st(std::mem_fun(&Dog::walkTheDog), &dog), 30);
std::bind1st(std::mem_fun(&Dog::walkTheDog), &dog)
返回一个类似函数的对象,它将成员函数绑定到特定的狗。从那时起,您可以像使用独立功能一样使用它。