参数类:
class Args
{
public:
Args(int iterations):mutex_(), iterations_(iterations){} //初始化列表
ACE_Thread_Mutex mutex_; //锁对象
int iterations_;
};
worker函数
void* worker (void * arguments)
{
//这里我没有用 iterations_,用全局变量number做了一个简单循环
Args arg= (Args) arguments;
while (::number>0)
{
LOG_INFO("yes i can" << number);
arg->mutex_.acquire(); //不加这个锁,number会错乱,加了锁,运行时崩溃
number -= 10;
arg->mutex_.release();
}
return NULL;
}
主程序
int n_threads = 3;
//定义即将新建的线程的线程ID和句柄
ACE_thread_t *threadID = new ACE_thread_t[n_threads+1];
ACE_hthread_t *threadHandles = new ACE_hthread_t[n_threads+1];
//启动线程组
if(ACE_Thread::spawn_n(
threadID, //线程ID
n_threads, //线程数
(ACE_THR_FUNC)worker, //线程执行的函数worker
0, //worker函数参数
THR_JOINABLE | THR_NEW_LWP, //flags
ACE_DEFAULT_THREAD_PRIORITY,
0, 0, threadHandles)==-1)
ACE_DEBUG((LM_DEBUG,"Error in spawning thread/n"));
//等待所有线程运行结束
for(int i=0; i < n_threads; i++)
{
ACE_Thread::join(threadHandles[i]);
}
加锁是需要的,那么你崩溃的地方是什么错误,你要再具体分析,比如先把number 加上volatile属性
为什么会出现这个问题?是锁加的位置不对么?