【Linux 编程】pthead_cond_t 的使用

本文通过两个示例程序详细介绍了pthread_cond_t在多线程环境下如何实现线程间的同步与等待。具体展示了如何利用pthread_cond_wait与pthread_cond_signal进行条件变量的等待与通知操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

pthead_cond_t 的使用
源代码1
 1 #include <stdio.h>
 2  #include <pthread.h>
 3  #include <stdlib.h>
 4  #include <unistd.h>
 5  
 6  pthread_cond_t qready = PTHREAD_COND_INITIALIZER;
 7  pthread_mutex_t qlock = PTHREAD_MUTEX_INITIALIZER;
 8  int constant = 0;
 9  
10  void *prints(void *arg)
11  {
12      pthread_mutex_lock(&qlock);
13      pthread_t tid = pthread_self();
14      while (constant <10)
15      {
16          pthread_cond_wait(&qready, &qlock);
17      }
18      printf("After while thread %u, Constant is %d\n", 
19              (unsigned int)tid, constant);
20      pthread_mutex_unlock(&qlock);
21      pthread_exit((void *)tid);
22  }
23  
24  void *incre(void *arg)
25  {
26      pthread_mutex_lock(&qlock);
27      pthread_t tid = pthread_self();
28      while ( ++constant < 20)
29      {
30          printf("In while thread %u, Constant is %d\n", 
31              (unsigned int)tid, constant);
32              
33          if (constant == 10) {   // 注意这里
34              pthread_mutex_unlock(&qlock);
35              pthread_cond_signal(&qready);
36              pthread_mutex_lock(&qlock);
37          }
38      }
39      printf("Now the constant is %d\n", constant);
40      /*
41      constant += 10;
42      if (constant == 10)
43          pthread_cond_signal(&qready);
44      */
45      pthread_mutex_unlock(&qlock);
46      
47      pthread_exit((void *)tid);
48  }
49  
50  int main()
51  {
52      int err;
53      pthread_t tid0, tid1;
54  
55      err = pthread_create(&tid0, NULL, prints, NULL);
56      if (err != 0)
57      {
58          printf("can't create thread: %d \n", strerror(err));
59          exit(0);
60      }
61      
62      sleep(1);
63      err = pthread_create(&tid1, NULL, incre, NULL);
64      if (err != 0)
65      {
66          printf("can't create thread: %d \n", strerror(err));
67          exit(0);
68      }
69      sleep(1);
70      
71      exit(0);
72  }
View Code

运行结果1

 
源代码2
 1 #include <stdio.h>
 2  #include <pthread.h>
 3  #include <stdlib.h>
 4  #include <unistd.h>
 5  
 6  pthread_cond_t qready = PTHREAD_COND_INITIALIZER;
 7  pthread_mutex_t qlock = PTHREAD_MUTEX_INITIALIZER;
 8  int constant = 0;
 9  
10  void *prints(void *arg)
11  {
12      pthread_mutex_lock(&qlock);
13      pthread_t tid = pthread_self();
14      while (constant <10)
15      {
16                  
17          pthread_cond_wait(&qready, &qlock);
18      }
19      printf("After while thread %u, Constant is %d\n", 
20              (unsigned int)tid, constant);
21      pthread_mutex_unlock(&qlock);
22      pthread_exit((void *)tid);
23  }
24  
25  void *incre(void *arg)
26  {
27      pthread_mutex_lock(&qlock);
28      pthread_t tid = pthread_self();
29      while ( ++constant < 20)
30      {
31          printf("In while thread %u, Constant is %d\n", 
32              (unsigned int)tid, constant);
33              
34          if (constant == 10) {    // 注意这里
35      //        pthread_mutex_unlock(&qlock);
36              pthread_cond_signal(&qready);
37      //        pthread_mutex_lock(&qlock);
38          }
39      }
40      printf("Now the constant is %d\n", constant);
41      /*
42      constant += 10;
43      if (constant == 10)
44          pthread_cond_signal(&qready);
45      */
46      pthread_mutex_unlock(&qlock);
47      
48      pthread_exit((void *)tid);
49  }
50  
51  int main()
52  {
53      int err;
54      pthread_t tid0, tid1;
55  
56      err = pthread_create(&tid0, NULL, prints, NULL);
57      if (err != 0)
58      {
59          printf("can't create thread: %d \n", strerror(err));
60          exit(0);
61      }
62      
63      sleep(1);
64      err = pthread_create(&tid1, NULL, incre, NULL);
65      if (err != 0)
66      {
67          printf("can't create thread: %d \n", strerror(err));
68          exit(0);
69      }
70      sleep(1);
71      
72      exit(0);
73  }
View Code
运行结果
 
  其中,虽然函数pthread_wait_cond()之前,该线程已经持有锁。但是在该函数阻塞时,将释放掉锁。因此,只有只有锁的线程释放掉,才能继续从pthread_wait_cond()之后执行,因为该函数将再次获得锁的控制权。

转载于:https://www.cnblogs.com/life91/archive/2013/05/27/3101009.html

基于Spring Boot搭建的一个多功能在线学习系统的实现细节。系统分为管理员和用户两个主要模块。管理员负责视频、文件和文章资料的管理以及系统运营维护;用户则可以进行视频播放、资料下载、参与学习论坛并享受个性化学习服务。文中重点探讨了文件下载的安全性和性能优化(如使用Resource对象避免内存溢出),积分排行榜的高效实现(采用Redis Sorted Set结构),敏感词过滤机制(利用DFA算法构建内存过滤树)以及视频播放的浏览器兼容性解决方案(通过FFmpeg调整MOOV原子位置)。此外,还提到了权限管理方面自定义动态加载器的应用,提高了系统的灵活性和易用性。 适合人群:对Spring Boot有一定了解,希望深入理解其实际应用的技术人员,尤其是从事在线教育平台开发的相关从业者。 使用场景及目标:适用于需要快速搭建稳定高效的在线学习平台的企业或团队。目标在于提供一套完整的解决方案,涵盖从资源管理到用户体验优化等多个方面,帮助开发者更好地理解和掌握Spring Boot框架的实际运用技巧。 其他说明:文中不仅提供了具体的代码示例和技术思路,还分享了许多实践经验教训,对于提高项目质量有着重要的指导意义。同时强调了安全性、性能优化等方面的重要性,确保系统能够应对大规模用户的并发访问需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值