我刚开始在大学里学习有关线程的一些知识,似乎我不太了解它.
我想让我的代码获取参数并检查它们是偶数还是质数,如果要输出,请打印它们.另外,将这些数字中的每一个相加.
这是代码:
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#define something 10
pthread_mutex_t lock=PTHREAD_MUTEX_INITIALIZER;
int snrp=0;
int sprim=0;
void * verif(void* argv){
pthread_mutex_lock(&lock);
int x=*(int*)argv;
if (x%2==0){
printf("%d is even\n",x);
snrp+=x;
}
else{
int ok=1;
int d;
if(x<1)
ok=0;
for(d=3;d*d<x;d+=2)
if(x%d==0)
ok=0;
if(ok==0)
return NULL;
printf("%d is prime\n",x);
sprim+=x;
}
pthread_mutex_unlock(&lock);
sleep(1);
return NULL;
}
int main(int argc,char* argv[]){
pthread_t threads[something];
int i,n;
for(i=1;i<argc;i+=1){
n=atoi(argv[i]);
if(pthread_create(&threads[i],NULL,verif,(void*) &n))
printf("Error");
}
for(i=1;i<argc;i+=1)
pthread_join(threads[i],NULL);
printf("Even numbers sum is %d \n",snrp);
printf("Prime numbers sum is %d \n",sprim);
pthread_mutex_destroy(&lock);
return 0;
}
例如,如果我使用参数2,3,5,我将得到输出:
5 is prime
5 is prime
5 is prime
Even numbers sum is 0
Prime numbers sum is 15
有人可以解释为什么吗?
解决方法:
@暗黑
void * verif(void * argv){
pthread_mutex_lock(& lock);
int x = *(int *)argv;
printf(“%p存储%d”,argv,n); //添加此行.在您的代码中.
您将了解,每次发送相同的地址,即发送相同的n(在示例中为5).为什么会这样?之所以发生这种情况,是因为在线程使用n之前,您已经在主函数中使用下一个命令行参数并行地对其进行了更改.
发生这种情况是因为在主程序中,所有三个参数都使用了相同的“ n”.而是推迟atoi函数并在verif()中使用它.直接从命令行参数传递argv.我可以为您完成pthread_create(..)函数的更改,但这是您的家庭作业.
祝好运.