linux多线程1

今天开始开发mis系统c++部分了,要将原来的同步请求改成异步请求。这个要用到多线程技术。第一次用到linux下的多线程技术,所以产生了好多的错误,这边做个小结。

 

在c++类中的成员函数是存在一个隐形的指针this的,所以不能将类的成员函数作为参数传给pthread_create,因为pthread_create需要的函数原型为void * func(void *args),这个问题的解决方法是将pthread_create的回调函数写成static的,但是又有了新的问题,static函数不能调用类的非static函数,所以这个问题就需要在创建线程的时候将类的this指针作为参数传给线程。同时由于我们将回调函数写成了静态的,所以用于存在记录的队列也必须写成静态的,同时为了保证多线程对于队列访问的同步性,用到了互斥锁,同样的将互斥锁作为类的静态数据成员保持。对于静态成员的使用是c++里面很麻烦的一个问题,尤其是初始化。下面是简单的介绍如何使用类的静态成员函数作为线程处理函数。

 

//MISService.h class MISService { private: struct ThreadArgs{ MISService * This; ThreadArgs(MISService * This):This(This){} }; void floodQueue(); static void* threadHandler(void *); private: static queue<RecordStruct*>inputqueue; static pthread_mutex_t lock; } //MISService.cpp pthread_mutex_t MISService::lock = PTHREAD_MUTEX_INITIALIZER; queue<RecordStruct*> MISService::inputqueue; void MISService::floodQueue() { int ret1 =0 ; pthread_t thread_id; for(int i = 0; i< THREAD_SIZE;++i){ ret1 = pthread_create(&thread_id,NULL,&MISService::threadHandler,new ThreadArgs(this)); } } void* MISService::threadHandler(void * args){ ThreadArgs * targs = static_cast<ThreadArgs*>(args); pthread_mutex_lock(&MISService::lock); RecordStruct * rs = NULL; if(inputqueue.size()>0){ rs = inputqueue.front(); inputqueue.pop(); } pthread_mutex_unlock(&MISService::lock); try { targs->This->_addToQueue(rs->input,rs->reason); delete rs; } catch(...){ } }

 

下面简单的介绍下如何对类的静态函数进行初始化:

//Test.h class Test{ private: static int a; private: static vector<int>b; private: static string c; private: static bool init; static bool __init(); } //Test.cpp int Test::a = 10;//initialize int variable vector<int> Test::b;//vector initialization string Test::c;//string initialization bool Test::init = Test::__init();//initialization with static member function;

 

你可能感兴趣的:(thread,多线程,linux,struct,function,delete)