计算1+1/2+1/3+......和1+1/2-1/3+1/4-1/5......
其中1/n由n个线程计算并使用写互斥写入中间数组,2个线程用读互斥从中间数组中读取结果分别进行1+1/2+1/3+......和1+1/2-1/3+1/4-1/5......的计算。
deepfuture@deepfuture-laptop:~/private/mytest$ gcc -lpthread -std=gnu99 -o test2 test2.c
test2.c: In function ‘myprint1’:
test2.c:32: warning: implicit declaration of function ‘sleep’
deepfuture@deepfuture-laptop:~/private/mytest$ ./test2
please input an integer:(<=1000)2
1/1 finished,push 1.0000000000
*******1/1:1.0000000000 computed result 1.0000000000
1/1:1.0000000000 added result 1.0000000000
1/2 finished,push 0.5000000000
1/2:0.5000000000 added result 1.5000000000
================add finish!============ result:1.5000000000
*******1/2:0.5000000000 computed result 0.5000000000
================compute finish!============ result:0.5000000000
deepfuture@deepfuture-laptop:~/private/mytest$ ./test2
please input an integer:(<=1000)3
1/1 finished,push 1.0000000000
1/1:1.0000000000 added result 1.0000000000
*******1/1:1.0000000000 computed result 1.0000000000
1/2 finished,push 0.5000000000
1/2:0.5000000000 added result 1.5000000000
*******1/2:0.5000000000 computed result 0.5000000000
1/3 finished,push 0.3333333333
*******1/3:0.3333333333 computed result 0.8333333333
================compute finish!============ result:0.8333333333
1/3:0.3333333333 added result 1.8333333333
================add finish!============ result:1.8333333333
deepfuture@deepfuture-laptop:~/private/mytest$ ./test2
please input an integer:(<=1000)4
1/1 finished,push 1.0000000000
1/1:1.0000000000 added result 1.0000000000
*******1/1:1.0000000000 computed result 1.0000000000
*******1/2:0.5000000000 computed result 0.5000000000
1/2 finished,push 0.5000000000
1/2:0.5000000000 added result 1.5000000000
1/3 finished,push 0.3333333333
*******1/3:0.3333333333 computed result 0.8333333333
1/3:0.3333333333 added result 1.8333333333
1/4 finished,push 0.2500000000
1/4:0.2500000000 added result 2.0833333333
================add finish!============ result:2.0833333333
*******1/4:0.2500000000 computed result 0.5833333333
================compute finish!============ result:0.5833333333
deepfuture@deepfuture-laptop:~/private/mytest$
#include <pthread.h> #include <bits/pthreadtypes.h> #include <stdio.h> #include <stdlib.h> #define MAXS 1000 double myjg[MAXS+1];//计算结果存放位置 int max; pthread_rwlock_t myrwlock; pthread_rwlockattr_t myrwlockattr; pthread_t threads[MAXS+2]; void *mycomp(void *x){//计算1/i的结果,计算结果放在一个数组中。 int i; pthread_rwlock_wrlock(&myrwlock); //互斥写锁,没有线程拥有互斥读锁时,可以加互斥写锁,临界区,完成对i的累加,保证不被多个线程同时修改i myjg[0]++; i=myjg[0];//myjg[0]存放着线程已经计算到的i。 pthread_rwlock_unlock(&myrwlock); myjg[i]=(1/(double)i); printf("1/%d finished,push %.10f\n",i,myjg[i]); } void *myprint1(void *xx){//读取数组,将计算结果累加,最终完成1/1+1/2+1/3+......+1/n的计算 int maxi; int curi=1; double jg=0; while(curi<=max) { sleep(1); pthread_rwlock_rdlock(&myrwlock); //互斥读锁,在互斥写解锁后可以有多个互斥读锁同时存在,临界区,取出正确的i,保证此时没有线程写i maxi=myjg[0]; pthread_rwlock_unlock(&myrwlock); for (;curi<=maxi;curi++){ jg+=myjg[curi]; printf("1/%d:%.10f added result %.10f\n",curi,myjg[curi],jg); } } printf("================add finish!============ result:%.10f\n",jg);//输出累加结果。 } void *myprint2(void *xx){//读取数组,将计算结果完成1/1+1/2-1/3+1/4-1/5......的计算 int maxi; int curi=1; int fh=1; double jg=0; while(curi<=max) { sleep(1); pthread_rwlock_rdlock(&myrwlock); //互斥读锁,在互斥写解锁后可以有多个互斥读锁同时存在,临界区,取出正确的i,保证此时没有线程写i maxi=myjg[0]; pthread_rwlock_unlock(&myrwlock); for (;curi<=maxi;curi++){ jg+=fh*myjg[curi]; printf("*******1/%d:%.10f computed result %.10f\n",curi,myjg[curi],jg); fh=-fh; } } printf("================compute finish!============ result:%.10f\n",jg);//输出累加结果 pthread_rwlock_destroy(&myrwlock); pthread_rwlockattr_destroy(&myrwlockattr); } int main(){ //计算1+1/2+1/3+......和1+1/2-1/3+1/4-1/5...... pthread_rwlockattr_init(&myrwlockattr); pthread_rwlockattr_setpshared(&myrwlockattr,PTHREAD_PROCESS_PRIVATE);//设置互斥为同一进程共享,也可设置为多个进程共享 pthread_rwlock_init(&myrwlock,&myrwlockattr); printf("please input an integer:(<=%d)",MAXS); while (scanf("%d",&max),max>MAXS){//n的最大值 printf("please input an integer:(<=%d)",MAXS); }; //深未来技术http://deepfuture.iteye.com/ myjg[0]=0; pthread_create(&(threads[0]),NULL,myprint1,NULL); pthread_create(&(threads[1]),NULL,myprint2,NULL); for (int i=2;i<=max+1;i++){ pthread_create(&(threads[i]),NULL,mycomp,NULL); sleep(1); } sleep(1); //for (int i=0;i<=max+1;i++){ // pthread_join(threads[i],NULL); // } return(0); }