使用ACE互斥锁进行线程同步,编译都没有问题,不加锁跑起来线程不同步很正常,加了锁,运行时崩溃

参数类:
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]);

2个回答

加锁是需要的,那么你崩溃的地方是什么错误,你要再具体分析,比如先把number 加上volatile属性

u013834105
Cleverly 代码中的worker参数写的0,应该是&arg
接近 3 年之前 回复
u013834105
Cleverly 问题找到了,内存访问冲突,没有给参数指针初始化,导致程序飞掉了
接近 3 年之前 回复

为什么会出现这个问题?是锁加的位置不对么?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问