void createThreads(int k){
struct threadData threadData[k];
int numThreads = k;
int i = 0;
int err = 0;
pthread_t *threads = static_cast<pthread_t*>(malloc(sizeof(pthread_t) * numThreads));
for(i = 0;i<numThreads;i++){
threadData[i].thread_id = i;
threadData[i].startIndex = ((N/k)*i);
threadData[i].stopIndex = ((N/k)*(i+1));
err = pthread_create(&threads[i], NULL, foo, (void *)&threadData[i]);
if(err != 0){
printf("error creating thread\n");
}
}
}
这里,N和k是整数,其中N / k的余数保证为0。 包括createThreads(numThreads);在主要将导致我的程序seg错误和注释它将照顾这个然而我放入createThreads(即使在函数内的第一行)的任何printf调试语句将不会显示所以我很困惑如何调试这个。感谢所有帮助。
答案 0 :(得分:2)
我想问题是你的arg参数在你的createThreads函数的堆栈上:
struct threadData threadData [k];
所以一旦你的线程被创建并运行,并且createThreads返回,threadData就不再有效了,所以你的线程函数不应该触及参数数据。否则它的未完成行为和崩溃。
所以要修复它,你应该,使threadData全局(在createThreads之外)或malloc它。