2

我有一个基于传递给进程的参数创建多个线程的进程。

producer_threads[num_threads];
for (id = 0; id < num_threads; id++)
{
    printf("%d\n", id);
    pthread_create(&producer_threads[id], NULL, &produce, (void *) &id);
}

每个线程进入生产函数并将 id 存储为局部变量

void* produce (void* args)
{
    int my_id = * (int*) args;
    printf("Thread %d started to produce\n", my_id);
}

但是我收到的输出如图所示

0
1
Thread <n> started to produce
Thread <n> started to produce

和 n 随机为 0、1 或 2。我不确定是什么导致了问题,除非是因为全局变量在本地分配之前正在更新。或者因为“局部变量”在线程之间共享。

4

2 回答 2

3

问题是您将指向同一变量的指针传递给每个线程。这会创建一个竞争条件,每个线程看到的变量值取决于确切的时间。

如果您通过值而不是指针传递线程参数,这将解决问题。

于 2012-06-05T20:43:29.803 回答
2

整数需要是分配变量而不是堆栈变量。由于您将指针传递到堆栈上的内存位置,因此您的结果将取决于时间(即竞争条件)。您需要将不同的变量传递给每个 pthread_create 调用。

于 2012-06-05T20:45:13.887 回答