【发布时间】:2019-02-26 02:48:55
【问题描述】:
所以我早些时候问了一个关于特定问题的问题。我已经查看了该站点上的其他问题,但其中大多数都没有处理我的问题,特别是尽管我认为这个问题对其他初学者很有用。代码如下。
(pi.h) 我的结构是如何布局的
#ifndef __PI_TEST_H
#define __PI_TEST_H
#include <stdio.h>
#include <stdlib.h>
struct piS //struct for threading
{
int threads; //amount of threads running
int iterations; //amount of iterations
int operation; //whether to add or subtract
double total; //value of pi
};
double calcPi(int numIter);
void *piPthreads(void *info);
#endif
(pi.c) 我如何将值放入 struct 并计算 pi
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <pthread.h>
#include "pi.h"
/***************************************************
* struct for pthreads
***************************************************/
void *piPthreads(void *arg)
{
struct piS *threader = (struct piS*) arg;
int operation = threader->operation; //rank
int threads = threader->threads; //count
int iterations = threader->iterations / threads;
double begin = operation * iterations;
double end = begin + iterations;
printf("iterations = %d\n",iterations);
threader->total = 0;
int plusMinus = 1;
if((int)begin%2)
plusMinus = -1;
double loop = begin;
printf("begin: %d, end: %d\n",begin, end);
for(loop = begin;loop < end;loop++)
{
if(plusMinus == 1)
{
threader->total += (1/(2*loop+1));
printf("threader->total = %d\n",threader->total);
}
else
{
threader->total -= (1/(2*loop+1));
printf("threader->total = %d\n",threader->total);
}
}
return NULL;
}
(pithreadDriver.c) 我如何运行 pthread 以及它是如何处理的
//driver class to run pthread
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include "pi.h"
/**********************************************
* main()
* handles command line arguments and passes
* for pThreads
**********************************************/
int main(int argc, char** argv){
int numIter = 100;
int pthread = 4;
//Handle command line args
if(argc != 3)
{
printf("Default:Number of threads being set to 4.\n");
printf("Default:Number of iterations set to 100.\n");
if(atoi(argv[2]) > 28)
{
printf("Default:Number of threads being set to 4\n");
printf("Max threads possible 28\n");
pthread = 4;
}
printf("Format for running:( executable iterations threads)\n");
}
if(argc == 3)
{
//Assign args
numIter = atoi(argv[1]);
//Assign threads
pthread = atoi(argv[2]);
}
//creating and handling pthreads
pthread_t *tids = (pthread_t*) malloc(sizeof(pthread_t) * pthread);
struct piS *threader = (struct piS*) malloc(sizeof(struct piS) * pthread);
int loop = 0;
//filling in values for pthreads and creating each thread
for(loop = 0;loop < pthread;loop++)
{
threader[loop].operation = loop;
threader[loop].threads = pthread;
threader[loop].iterations = numIter;
printf("threader[%d].iterations = %d\n",loop,threader[loop].iterations);
pthread_create(&tids[loop],NULL,piPthreads,&threader);
}
double answer = 0;
for(loop = 0;loop < pthread; loop++)
{
pthread_join(tids[loop],NULL);
answer += threader[loop].total;
printf("threader[%d] = %d\n",loop,threader[loop].total);
}
answer = answer * 4;
printf("answer is %f using %d iterations\n",answer,numIter);
return 0;
}
(out.txt) 运行时输出
Default:Number of threads being set to 4.
Default:Number of iterations set to 100.
Format for running:( executable iterations threads)
threader[0].iterations = 100
threader[1].iterations = 100
threader[2].iterations = 100
iterations = 0
begin: 0, end: 0
threader[3].iterations = 100
iterations = 0
begin: 0, end: 0
threader[0] = 0
threader[1] = 1
iterations = 0
begin: 0, end: 0
iterations = 0
begin: 0, end: 0
threader[2] = 2
threader[3] = 3
answer is 0.000000 using 100 iterations
我可以看到线程运行正常。我还可以看到为什么它没有进入我的 for 循环来解决实际计算。其中大部分是教练向我们展示的代码,它只是真正触及但没有结束。我已经尝试在我的 pic.c 中使用 print 语句来弄清楚。我可以看到迭代值没有被正确放置。从我得到的这段代码来看,它不会按照我想要的方式运行。但是我在弄清楚为什么我的迭代没有通过时遇到问题。
【问题讨论】:
-
在
if(argc == 3)...内创建新变量,而外部变量保持不变。 -
真病删除声明并只分配值。谢谢。
-
另外,我相信
pthread_create的最后一个参数是错误的。不应该是&threader[loop]吗? -
@JohnnyMopp dbush 帮助解释了它,但感谢您指出。