/
//代码
#include <cstdio>
#include <pthread.h>
#include <semaphore.h>
#include <unistd.h>
template <class T>
class thread_proxy_imp
{
protected:
typedef struct
{
T *obj;
void (T::*start_routine)(void *);
void *arg;
sem_t sem;
} thread_param;
static void *thread_proxy_entry (void *arg)
{
thread_param *param_ptr = static_cast<thread_param *> (arg);
thread_param param = *param_ptr;
sem_post (¶m_ptr->sem);
/* 注意 ->* 操作符 */
(param.obj->*param.start_routine) (param.arg);
}
public:
int pthread_create (
T *obj,
pthread_t *thread,
const pthread_attr_t *attr,
void (T::*start_routine)(void *),
void *arg)
{
int rt;
thread_param param = {obj, start_routine, arg};
/* 为防止param在新线程使用它之前被析构,加上一个semaphore. */
sem_init (¶m.sem, 0, 0);
C++ 类非静态成员函数作为线程入口函数实现
最新推荐文章于 2022-05-23 13:25:49 发布
本文展示了如何在C++中利用模板类`thread_proxy_imp`,将类的非静态成员函数作为线程的入口点。通过创建一个结构体`thread_param`持有对象指针和成员函数指针,使用`thread_proxy_entry`静态函数作为线程实际执行的起点,实现了在新线程中调用非静态成员函数的功能。在`C`类中创建线程并执行`thread_entry`函数,输出传入参数`arg`的值。
摘要由CSDN通过智能技术生成