gpt4 book ai didi

c - 在 C 中使用多线程显示质数

转载 作者:太空宇宙 更新时间:2023-11-04 04:22:41 32 4
gpt4 key购买 nike

在函数 printprime 中,我用四个线程中的每一个迭代每个元素,这几乎等同于一个单线程程序。我想将 i 增加 i=i+MAX_THREADS。我正在使用四个线程,因为我的笔记本电脑有四个处理器并且已经过全面优化。谁能告诉我如何调整 printprime 以便每个线程迭代一个数字。比如,线程 1 检查 2、6、10...线程 2 检查 3、7、11...等等。

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

#define N 30
#define MAX_THREADS 4

int prime_arr[N] = { 0 };

void *printprime(void *ptr) {
int j, flag;
int i = (int)(long long int)ptr;
for (i = 2; i < N; i++) {
flag = 0;
for (j = 2; j <= i / 2; j++) {
if (i % j == 0) {
flag = 1;
break;
}
}

if (flag == 0) {
prime_arr[i] = 1;
}
}
}

int main() {
pthread_t tid[MAX_THREADS] = {{ 0 }};
int count = 0;
for (count = 0; count < MAX_THREADS; count++) {
printf("\r\n CREATING THREADS %d", count);
pthread_create(&tid[count], NULL, printprime, (void *)count);
}
printf("\n");
for (count = 0; count < MAX_THREADS; count++) {
pthread_join(tid[count], NULL);
}

int c = 0;
for (count = 0; count < N; count++)
if (prime_arr[count] == 1)
printf("%d ", count);

return 0;
}

最佳答案

为了达到理想效果,将函数 void *printprime(void *ptr) 中的变量 i 增加 MAX_THREADS(在您的例子中为 4)。

注意printf("Thread id[%d] checking [%d]\n",pthread_self(),i); 用于显示哪个线程正在检查哪个值。

以下代码可能会有帮助:

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

#define N 30
#define MAX_THREADS 4

int prime_arr[N]={0};

void *printprime(void *ptr)
{
int j,flag;
int i=(int)(long long int)ptr;
while(i<N)
{
printf("Thread id[%d] checking [%d]\n",pthread_self(),i);
flag=0;
for(j=2;j<=i/2;j++)
{
if(i%j==0)
{
flag=1;
break;
}
}

if(flag==0 && (i>1))
{
prime_arr[i]=1;
}
i+=MAX_THREADS;
}
}

int main()
{
pthread_t tid[MAX_THREADS]={{0}};
int count=0;
for(count=0;count<MAX_THREADS;count++)
{
printf("\r\n CREATING THREADS %d",count);
pthread_create(&tid[count],NULL,printprime,(void*)count);
}
printf("\n");
for(count=0;count<MAX_THREADS;count++)
{
pthread_join(tid[count],NULL);
}

int c=0;
for(count=0;count<N;count++)
if(prime_arr[count]==1)
printf("%d ",count);

return 0;
}

关于c - 在 C 中使用多线程显示质数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44881796/

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