gpt4 book ai didi

c - pthread 导致的段错误?

转载 作者:太空宇宙 更新时间:2023-11-04 01:09:34 29 4
gpt4 key购买 nike

几个小时以来,我一直在努力寻找导致此段错误的原因。

我发现段错误始终出现在 pthread_mutex_lock(lock) 行 (38) 上。我在锁周围放置了两个打印语句,但是只有其中一个被打印出来,这是我断定段错误发生在该指令上的理由。

我是否正确使用了互斥锁,还是我的数组 (buffer[]numbermarker[] 有误?

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>

int* numbermarker = NULL;
int* buffer = NULL;
int pullposition = 0;
int placeposition = 1;
pthread_mutex_t *lock;
int ceiling;

/*This method places one of the primes in the buffer. It
offers a safe way to manage where the next value will be placed*/
void placevalue(int value)
{
buffer[placeposition] = value;
placeposition++;
}

/*This method pulls the next prime and increments to the next prime in the list*/
int takevalue()
{
pullposition++;
return buffer[pullposition-1];
}


void* threadmethod()
{
int k;
int l;
int firstval;
while(1)
{
while(numbermarker[buffer[pullposition]-1]==0)
{
printf("flag1 \n");
pthread_mutex_lock(lock);
printf("flag2 \n");
numbermarker[buffer[pullposition]-1] = 1;
l = takevalue();
pthread_mutex_unlock(lock);
firstval = 1;
for(k=l+1;k<=ceiling;k++)
{
if(k%l != 0)
{
if(firstval)
{
placevalue(k);
firstval = 0;
}
}
else
{
numbermarker[k-1] = 1;
}
}
}
}
}


int main()
{
int numthreads;
int i;

printf("Enter number of threads: \n");
scanf("%d", &numthreads);

printf("Enter the highest value to check \n");
scanf("%d", &ceiling);

/* This will hold 1's and 0's.
1 = number has been checked or is
confirmed not to be a prime
0 = number is a possible prime

The idea behind these values is that the next
prime can always be identified by the 0 with
the lowest index*/
numbermarker = (int*)malloc(sizeof(int)*(ceiling));

/*This will hold the primes as they are found*/
buffer = (int*)malloc(sizeof(int)*(ceiling));

for(i=0; i<ceiling; i++)
{
if(i<1)
{
numbermarker[i] = 1;
}
else
{
numbermarker[i] = 0;
}

buffer[i]=0;
printf("%d \n",numbermarker[i]);
}

placevalue(2);

pthread_t **tid = (pthread_t **) malloc(sizeof(pthread_t *) * numthreads);


for(i=0;i<numthreads;i++)
{

tid[i] = (pthread_t *) malloc(sizeof(pthread_t));
}

for(i=0;i<numthreads;i++)
{

if(pthread_create(tid[i],
NULL,
threadmethod,
NULL))
{

printf("Could not create thread \n");
exit(-1);
}
}


int not_done = 1;
int sum;
while(not_done)
{
sum = 0;
for(i=0; i<ceiling; i++)
{
sum += numbermarker[i];
}
if(sum == ceiling)
not_done = 0;
}
for(i=0;i<numthreads;i++)
{
if(pthread_join(*tid[i], NULL))
{
printf("Error Joining with thread \n");
}
free(tid[i]);
}
free(tid);




for(i=0;i<ceiling;i++)
{
if(buffer[i] != 0);
printf("%d \n", i);
}
free(buffer);
free(numbermarker);
buffer=NULL;
numbermarker=NULL;


return(0);

最佳答案

lock 是一个未初始化的指针。您需要分配内存,然后在锁定互斥锁之前初始化互斥锁。最简单的解决方法是更改​​

pthread_mutex_t *lock;

pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;

和(因为 lock 不再是一个指针)

pthread_mutex_lock(lock);
....
pthread_mutex_unlock(lock);

pthread_mutex_lock(&lock);
....
pthread_mutex_unlock(&lock);

关于c - pthread 导致的段错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15828593/

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