クラス関数を pthread_create() に渡す
メンバー関数「print」を含む C クラスがあるシナリオを考えてみましょう。これを別のスレッドで実行したいのですが、 pthread_create() ただし、コンパイル エラーが発生しました:
pthread_create(&t1, NULL, &c[0].print, NULL);
このエラーは、C クラスのメンバー関数に現在のクラスを指す this が暗黙的に含まれていることが原因で発生します。ポインタを最初のパラメータとして使用します。ただし、 pthread_create() は標準関数ポインターを予期しますが、標準関数ポインターには this ポインターがありません。したがって、コンパイラーは、そのような関数ポインターを pthread_create() で必要な関数型に変換できません。
解決策
この問題を解決するには、pthread_create() からクラス メンバー関数を呼び出せる別のアプローチを採用する必要があります。一般的なアプローチは 2 つあります。
静的クラス メソッドの使用
静的クラス メソッドには、特定のクラス インスタンスに関連付けられていないため、このポインターは含まれません。次のように通常の関数のように呼び出すことができます。
class C { public: static void *hello(void) { std::cout << "Hello, world!" << std::endl; return 0; } }; int main() { pthread_t t; pthread_create(&t, NULL, &C::hello, NULL); ... }
ラッパー関数の使用
もう 1 つの方法は、通常の関数ラッパーとしてラップされたクラス メンバー関数を作成することです。関数。このラッパー関数は、最初の引数としてクラス インスタンスを受け取り、次のようにメンバー関数を呼び出します:
class C { public: void *hello(void) { std::cout << "Hello, world!" << std::endl; return 0; } static void *hello_helper(void *context) { return ((C *)context)->hello(); } }; int main() { C c; pthread_t t; pthread_create(&t, NULL, &C::hello_helper, &c); ... }
以上がC クラスのメンバー関数を pthread_create() に渡すにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。