多线程共享数据

发布时间:2020-04-29 12:22:01 作者:lingftgy
来源:网络 阅读:486

线程间的数据共享

     多个线程共享数据, A线程生产物品,产品数量增加,B线程使用,那么产品数量减少,B线程如何知道产品buf是否为空呢?A线程如何判断产品buf为满?
1 轮询机制
      线程每隔一定时间检查缓冲区,如果有产品就取出,这种机制需要控制好轮询间隔,查询太频繁会导致占用cpu过多,浪费;查询太不频繁导致缓冲区满,生产者放不进去产品
  int buf[MAX];
  int ProductionCount;
  while(1)
  {
  Msleep(100);
     if(ProductionCount > 0)
       {
        use it;
     ProductionCount --;
    }
  }
 2,信号量机制
      信号量和线程,互斥锁等一样,是操作系统提供的功能
   对于上述问题,可以创建一个信号量对象,生产线程每次生产完可以调用post使得信号量+1,消费只调用wait函数;使信号量减1,如果信号量为0,消费线程会等待,,
   Semaphore sem(0);
   A线程
       while(1)
    {
        ...
     sem.post();
    }
     B线程
      while(1)
   {
       ....
    sem.wait();      //如果信号量为0,那么会等待,
   }
 超时等待
 int res = sem。wait(1000); //ms
 if( res != 0)
    。。。。。;
 如果等待超过 1000秒,那么res返回 !0,可以执行某些操作。。
 



 


推荐阅读:
  1. aidl通过回调共享数据
  2. 页面共享数据的有效范围

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

通信 多线程 信号量

上一篇:docker入门之容器网络

下一篇:mysql之数据备份还原

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》