编写一个程序,开启3个线程,这3个线程的ID分别为A、B、C,每个线程将自己的ID在屏幕上打印10遍

编写一个程序,开启3个线程,这3个线程的ID分别为A、B、C,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示;如:ABCABC….依次递推。

#include <stdio.h>   
  1. #include <stdlib.h>   
  2. #include <pthread.h>   
  3. #include <unistd.h>   
  4. #include <string.h>   
  5. //#define DEBUG 1   
  6. #define NUM 3   
  7.   
  8. int n=0;  
  9. pthread_mutex_t mylock=PTHREAD_MUTEX_INITIALIZER;//互斥量  
  10. pthread_cond_t qready=PTHREAD_COND_INITIALIZER;//条件变量  
  11.   
  12.   
  13. void * thread_func(void *arg)  
  14. {  
  15.     int param=(int)arg;  
  16.     char c='A'+param;  
  17.     int ret,i=0;  
  18.     for (; i < 10; i++)  
  19.     {  
  20.         pthread_mutex_lock(&mylock);  
  21.         while (param != n)  //刚运行时,n = 0, param = 0,条件不成立,所以直接打印A  
  22.         {  
  23. #ifdef DEBUG   
  24.             printf("thread %d waiting\n", param);  
  25. #endif   
  26.             ret = pthread_cond_wait(&qready, &mylock);  
  27.             if (ret == 0)   
  28.             {  
  29. #ifdef DEBUG   
  30.                 printf("thread %d wait success\n", param);  
  31. #endif   
  32.             } else   
  33.             {  
  34. #ifdef DEBUG   
  35.                 printf("thread %d wait failed:%s\n", param, strerror(ret));  
  36. #endif   
  37.             }  
  38.         }  
  39.        // printf("%d ",param+1);   
  40.         printf("%c ",c);  //打印A后  
  41.         n=(n+1)%NUM;      //n变成了1,对线程2会产出影响!!!!  
  42.         pthread_mutex_unlock(&mylock);  
  43.         //会唤醒所有的线程,因为当这个线程完后会等pthread_cond_wait()执行两次后才能退出while (param != n)  
  44.         pthread_cond_broadcast(&qready);  
  45.           
  46.     }      
  47.     return (void *)0;  
  48. }  
  49.   
  50. #if 0   
  51. //假设为线程2   
  52.   
  53. void * thread_func(void *arg)//传入值1  
  54. {  
  55.     int param=(int)arg;  
  56.     char c='A'+param;  
  57.     int ret,i=0;  
  58.     for (; i < 10; i++)  
  59.     {  
  60.         pthread_mutex_lock(&mylock);  
  61.         while (param != n)  //和线程1同时执行,所以刚开始时条件满足  
  62.         {  
  63. #ifdef DEBUG   
  64.             printf("thread %d waiting\n", param);  
  65. #endif   
  66.             //执行到此时,等待线程1发送信号,当线程1的A打印完后,n的值也变成了1,条件就不成立了  
  67.             ret = pthread_cond_wait(&qready, &mylock);  
  68.             if (ret == 0)   
  69.             {  
  70. #ifdef DEBUG   
  71.                 printf("thread %d wait success\n", param);  
  72. #endif   
  73.             } else   
  74.             {  
  75. #ifdef DEBUG   
  76.                 printf("thread %d wait failed:%s\n", param, strerror(ret));  
  77. #endif   
  78.             }  
  79.         }  
  80.        // printf("%d ",param+1);  
  81.         printf("%c ",c); //此时打印值B  
  82.         n=(n+1)%NUM;    //对打印C的线程3产生影响!!!  
  83.         pthread_mutex_unlock(&mylock);  
  84.         pthread_cond_broadcast(&qready);  
  85.     }      
  86.     return (void *)0;  
  87. }  
  88.   
  89. #endif   
  90.   
  91. int main(int argc, char** argv) {  
  92.       
  93.     int i=0,err;  
  94.     pthread_t tid[NUM];  
  95.     void *tret;  
  96.     for(;i<NUM;i++)  
  97.     {  
  98.         err=pthread_create(&tid[i],NULL,thread_func,(void *)i);  
  99.         if(err!=0)  
  100.         {  
  101.             printf("thread_create error:%s\n",strerror(err));  
  102.             exit(-1);  
  103.         }  
  104.     }  
  105.     for (i = 0; i < NUM; i++)  
  106.     {  
  107.         err = pthread_join(tid[i], &tret);  
  108.         if (err != 0)  
  109.         {  
  110.             printf("can not join with thread %d:%s\n", i,strerror(err));  
  111.             exit(-1);  
  112.         }  
  113.     }  
  114.     printf("\n");  
  115.     return 0;  
  116. }  
结果如下:

你可能感兴趣的:(JOIN,thread,c,null)