我正在尝试使用信号量实现合并排序,我在运行代码时遇到了一些麻烦:
sem_t *sem;
pthread_t *t;
void *parallel_merge_sort(void *thread_id)
{
int a = *((int *) thread_id);
printf("%d. in sort\n",a);
fflush(stdout);
sem_post(&(sem[a]));
if(a % 2)
sem_wait(&(sem[a-1]));
else
sem_wait(&(sem[a+1]));
printf("%d. out sort\n",a);
fflush(stdout);
}
void main()
{
int P = 2,i;
t = calloc(P,sizeof(pthread_t));
sem = calloc(P,sizeof(sem_t));
printf("threads created\n");
fflush(stdout);
for(i=0;i<P;i++)
pthread_create(&(t[i]),NULL,(void*) ¶llel_merge_sort,(void *) &i);
for(i=0;i<P;i++)
pthread_join(t[i], NULL);
printf("threads end\n");
fflush(stdout);
}
此代码生成如下输出:
threads created
0. in sort
0. in sort
在此之后,它不会继续运行并等待。
问题是什么,我该如何解决?
答案 0 :(得分:0)
无法保证新线程立即启动。这意味着您不能使用指向索引的指针,因为变量可能会在线程启动之前发生变化。
在这种情况下,似乎线程在主线程进入第二个循环之后才开始,其中变量i
被重置为零,因此两个线程将具有相同的索引,试图在同一个信号量上等待的线程。
你可以通过使用“hack”绕过这个并直接传递i
作为指针:
pthread_create(&(t[i]),NULL,(void*) ¶llel_merge_sort,(void *) i);
在线程函数中执行:
int a = (int) thread_id;