멀티스레딩 영역에서는 스레드 실행 내에서 클래스의 멤버 함수를 호출해야 하는 경우가 흔히 발생합니다. 그러나 이 작업은 C 클래스 멤버 함수의 숨겨진 "this" 매개 변수로 인해 문제가 발생할 수 있습니다.
예를 들어 다음을 고려하세요.
class C { void *print(void *) { cout << "Hello"; } };
이제 벡터를 만들어 보겠습니다. C 인스턴스:
vector<C> classes; pthread_t t1; classes.push_back(C()); classes.push_back(C());
c.print()를 실행하는 스레드를 생성하려면 직관적으로 쓰기:
pthread_create(&t1, NULL, &c[0].print, NULL);
그러나 이렇게 하면 오류가 발생합니다.
cannot convert ‘void* (tree_item::*)(void*)’ to ‘void* (*)(void*)’
pthread_create()가 특정 유형의 함수 포인터를 기대하는 반면 c[0]에서는 문제가 발생합니다. .print는 숨겨진 "this" 매개변수가 있는 멤버 함수에 대한 포인터입니다.
이 장애물을 극복하려면 두 가지 옵션이 있습니다.
정적 클래스 메서드에는 "this" 매개변수가 없으며 매개변수 없이 직접 호출할 수 있습니다. 클래스의 인스턴스. hello 함수에 대한 정적 클래스 메서드를 구현하는 방법은 다음과 같습니다.
class C { public: static void *hello(void *) { std::cout << "Hello, world!" << std::endl; return 0; } };
그런 다음 정적 클래스 메서드를 사용하여 스레드를 생성할 수 있습니다.
pthread_create(&t, NULL, &C::hello, NULL);
또 다른 옵션은 멤버 함수를 캡슐화하고 "this" 매개변수를 명시적으로 제공하는 함수 포인터를 사용하는 것입니다. 그런 다음 이 함수 포인터를 사용하여 스레드를 생성할 수 있습니다.
C c; pthread_create(&t, NULL, &C::hello_helper, &c);
여기서 hello_helper는 다음과 같이 정의됩니다.
void *hello_helper(void *context) { return ((C *)context)->hello(); }
정적 클래스 메서드나 함수 포인터를 사용하면 안전하게 다음을 수행할 수 있습니다. 스레드 내에서 클래스의 멤버 함수를 호출하여 "this" 매개변수 문제를 방지합니다.
위 내용은 스레드에서 C 클래스 멤버 함수를 안전하게 호출하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!