我正在做一个家庭作业,我必须在C中编写一个多线程的Linux程序来解决操作系统类的生产者 - 消费者问题。在我的代码中,我有一个while
循环,它位于由单个线程运行的函数中。在那个函数中,我有一个增量到一个被mutex
保护的变量。多线程程序在循环加时间运行
问题是,有时,while
循环会比我预期的运行时间多出一段时间。例如,当我期望循环执行16
次时,它将有时执行17
次。我无法弄清楚这个错误的原因,但它似乎与线程有关。我已经最小化了我的代码,问题仍然是可重现的。
#include <stdio.h>
#include <string.h>
#include <pthread.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
int numItems = 16;
pthread_t threadID;
pthread_t threadID2;
pthread_mutex_t mutex;
pthread_attr_t attr;
void *produce(void *param);
int numItemsProduced = 0;
int main(int argc, char *argv[])
{
pthread_attr_init(&attr);
// Initialize mutex.
if (pthread_mutex_init(&mutex, NULL) != 0)
{
printf("%s\n", "An error occured while initializing mutex!");
}
pthread_create(&threadID, &attr, produce, NULL);
pthread_create(&threadID2, &attr, produce, NULL);
pthread_join(threadID, NULL);
pthread_join(threadID2, NULL);
printf("Finished.\n");
}
void *produce(void *param)
{
printf("In thread.\n");
while (numItemsProduced < numItems)
{
pthread_mutex_lock(&mutex);
printf("Current while loop is at int %d\n", numItemsProduced);
numItemsProduced++;
pthread_mutex_unlock(&mutex);
}
pthread_exit(0);
}
为什么while
循环有时会执行额外的时间?我相信我正确使用了mutex
。
请问'打破;'语句跳过'调用pthread_mutex_unlock(互斥);'和导致死锁? – Steven
你是对的,更新为使用RAII – acgull
删除'break;'语句并将'if'块留空可防止死锁?我不太了解RAII,并且不习惯使用它。 – Steven