gpt4 book ai didi

c - 生产者-消费者 c - 更大值的段错误

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:06:26 24 4
gpt4 key购买 nike

我正在用 c 中的两个线程解决一个生产者一个消费者问题。我使用一个共享链表来做到这一点,生产者在其中放置一些东西,而消费者从同一个列表中获取它。我必须使用 2 个值 N 和 B(N 是要传输的数据的大小,B 是共享链表的最大大小)来运行我的代码。(./thread-a1 N B)此代码对于小值运行良好。但是,对于 N = 20,000 和 B = 16,它会给出 Segmentation fault: 11我不知道为什么会这样。请帮忙

#include<time.h>
#include<sys/time.h>
#include<stdlib.h>
#include<stdio.h>
#include<pthread.h>
#include<unistd.h>

struct job
{
int data;
struct job* next;
};

struct job* head;
int maxSize;
int n;
pthread_mutex_t m = PTHREAD_MUTEX_INITIALIZER;

int getCount()
{
int count = 0;
struct job* p = head;
while(p != NULL)
{
p = p -> next;
count++;
}
return count;
}

void Insert(int x)
{

struct job* temp = (struct job*)malloc(sizeof(struct job));
temp -> data = x;
if (head == NULL)
{
temp -> next = NULL;
}
else
{
temp -> next = head;
}
head = temp;
}

void Delete()
{

struct job *toDelete, *secondLastNode;

if(head == NULL)
{

}
else
{
toDelete = head;
secondLastNode = head;


while(toDelete->next != NULL)
{

secondLastNode = toDelete;
toDelete = toDelete->next;
}
printf("%d, ", toDelete -> data);

if(toDelete == head)
{
free(toDelete);
head = NULL;
}
else
{
secondLastNode->next = NULL;
free(toDelete);
}

}
}

void* producer(void* arg)
{
pthread_mutex_lock(&m);
head = NULL;

int i;
for (i = 0; i<n; i++)
{

while(getCount() >= maxSize)
{
pthread_mutex_unlock(&m);
}
Insert(i);
}

return NULL;
}

void* consumer(void* arg)
{
pthread_mutex_lock(&m);
int i;
for (i=0; i<n; i++)
{
while(getCount() <= 0)
{
pthread_mutex_unlock(&m);
}
Delete();
}


return NULL;
}

int main(int argc, char *argv[])
{

struct timeval start_init, end_init;
gettimeofday(&start_init, NULL);
n = atoi(argv[1]);
maxSize = atoi(argv[2]);

pthread_t thread1;
pthread_t thread2;
gettimeofday(&end_init, NULL);
printf("Time elapsed for initialization is: %ld\n",
(long)(end_init.tv_sec*1000000 + end_init.tv_usec) - (start_init.tv_sec*1000000 + start_init.tv_usec));

struct timeval start_trans, end_trans;
gettimeofday(&start_trans, NULL);
pthread_create(&thread1, NULL, &producer, NULL);
pthread_create(&thread2, NULL, &consumer, NULL);

pthread_join(thread1, NULL);
pthread_join(thread2, NULL);
gettimeofday(&end_trans, NULL);
printf("Time elapsed for transmission is: %ld\n",
(long)(end_trans.tv_sec*1000000 + end_trans.tv_usec) - (start_trans.tv_sec*1000000 + start_trans.tv_usec));


return 0;
}

最佳答案

您需要重新访问您的锁定;您只在每个生产者和消费者开始时获取锁,然后只解锁它们(重复!),这意味着不会发生进一步的同步。您的程序运行的时间越长,这种缺乏同步的情况就越有可能使您的程序出错。

关于c - 生产者-消费者 c - 更大值的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39835998/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com