5

メンバー関数の呼び出しを並列化するために使用する QFuture を作成します。より正確には、クラス solveParallel と .h があります。

class solverParallel {
public:
  solverParallelData(Manager* mgr_);
  virtual ~solverParallel(void);

  void runCompute(solveModel * model_);

  bool resultComput();

private:
  Manager *myMgr;
  QFuture<bool> myFutureCompute;
}; 

ここで、メソッド runCompute() は myFutureCompute メンバーを作成しています。.cppは次のようになります

solveParallel::solveParallel(Manager* mgr_)
:m_mgr(mgr_)
{
}

solverParallel::~solverParallel(void){}

void solverParallel::runCompute(solveModel* model)
{
  futureComput = QtConcurrent::run(&this->myMgr,&Manager::compute(model));
}

bool solverParallelData::resultComput()
{
  return m_futureComput.result();
}

インクルードは大丈夫です。オンラインでのコンパイルの失敗

futureComput = QtConcurrent::run(&this->myMgr,&Manager::compute(model));

このエラーで:

Error   44  error C2784: 'QFuture<T> QtConcurrent::run(T (__cdecl *)(Param1),const     Arg1 &)' : could not deduce template argument for 'T (__cdecl *)    (Param1)' from 'Manager **'   solverparallel.cpp 31

さらに、同じコード行の '&Manager' のマウス情報では、次のようになります: エラー: 非静的メンバー参照は特定のオブジェクトに対して相対的でなければなりません。

トリックがどこにあるかわかりますか?ありがとうございます。

4

1 に答える 1

14

公式ドキュメントから:

QtConcurrent::run() はメンバー関数へのポインターも受け入れます。最初の引数は、const 参照またはクラスのインスタンスへのポインターである必要があります。const 参照による受け渡しは、const メンバー関数を呼び出すときに便利です。ポインターによる受け渡しは、インスタンスを変更する非 const メンバー関数を呼び出すのに役立ちます。

ポインターにポインターを渡しています。また、引数をこのように渡すことはできず、run関数内の追加の引数として渡すことにも注意してください。以下が機能するはずです。

futureComput = QtConcurrent::run(this->myMgr,&Manager::compute, model);
于 2012-04-03T15:24:44.510 に答える