编写一个程序,开启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. }  
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>
#include <string.h>
//#define DEBUG 1
#define NUM 3

int n=0;
pthread_mutex_t mylock=PTHREAD_MUTEX_INITIALIZER;//互斥量
pthread_cond_t qready=PTHREAD_COND_INITIALIZER;//条件变量


void * thread_func(void *arg)
{
    int param=(int)arg;
    char c='A'+param;
    int ret,i=0;
    for (; i < 10; i++)
    {
        pthread_mutex_lock(&mylock);
        while (param != n)  //刚运行时,n = 0, param = 0,条件不成立,所以直接打印A
        {
#ifdef DEBUG
            printf("thread %d waiting\n", param);
#endif
            ret = pthread_cond_wait(&qready, &mylock);
            if (ret == 0) 
            {
#ifdef DEBUG
                printf("thread %d wait success\n", param);
#endif
            } else 
            {
#ifdef DEBUG
                printf("thread %d wait failed:%s\n", param, strerror(ret));
#endif
            }
        }
       // printf("%d ",param+1);
        printf("%c ",c);  //打印A后
        n=(n+1)%NUM;      //n变成了1,对线程2会产出影响!!!!
        pthread_mutex_unlock(&mylock);
		//会唤醒所有的线程,因为当这个线程完后会等pthread_cond_wait()执行两次后才能退出while (param != n)
        pthread_cond_broadcast(&qready);
		
    }    
    return (void *)0;
}

#if 0
//假设为线程2

void * thread_func(void *arg)//传入值1
{
    int param=(int)arg;
    char c='A'+param;
    int ret,i=0;
    for (; i < 10; i++)
    {
        pthread_mutex_lock(&mylock);
        while (param != n)  //和线程1同时执行,所以刚开始时条件满足
        {
#ifdef DEBUG
            printf("thread %d waiting\n", param);
#endif
			//执行到此时,等待线程1发送信号,当线程1的A打印完后,n的值也变成了1,条件就不成立了
            ret = pthread_cond_wait(&qready, &mylock);
            if (ret == 0) 
            {
#ifdef DEBUG
                printf("thread %d wait success\n", param);
#endif
            } else 
            {
#ifdef DEBUG
                printf("thread %d wait failed:%s\n", param, strerror(ret));
#endif
            }
        }
       // printf("%d ",param+1);
        printf("%c ",c); //此时打印值B
        n=(n+1)%NUM;    //对打印C的线程3产生影响!!!
        pthread_mutex_unlock(&mylock);
        pthread_cond_broadcast(&qready);
    }    
    return (void *)0;
}

#endif

int main(int argc, char** argv) {
    
    int i=0,err;
    pthread_t tid[NUM];
    void *tret;
    for(;i<NUM;i++)
    {
        err=pthread_create(&tid[i],NULL,thread_func,(void *)i);
        if(err!=0)
        {
            printf("thread_create error:%s\n",strerror(err));
            exit(-1);
        }
    }
    for (i = 0; i < NUM; i++)
    {
        err = pthread_join(tid[i], &tret);
        if (err != 0)
        {
            printf("can not join with thread %d:%s\n", i,strerror(err));
            exit(-1);
        }
    }
    printf("\n");
    return 0;
}
结果如下:
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值