OpenThreads使用-Block

Block简介

Block,障碍物,阻塞。
Block用来暂停一个线程,等待另一个线程来释放它。
线程A通过Block对自身进行阻塞,然后另一个线程B释放障碍物,使得线程A继续运行。

Block使用

block函数:通过调用block函数,阻塞调用线程。带参数的则表示阻塞线程n毫秒以后,自动释放block。
release函数:释放阻塞的线程。
reset函数:重置阻塞。即又重新开始阻塞线程。
set函数:参数为doRelease,为true时,释放阻塞,线程继续运行,否则阻塞线程。

下面这个程序,开启A,B线程,去售票,然后主线程自己阻塞。当A卖完10张票以后,释放Block,主线程继续运行,去开启C线程售票。同时A阻塞自己,停止售票。当B和C都售票完毕后,主线程再释放Block,让A开始售票。

#include <OpenThreads/Thread>
#include <OpenThreads/Atomic>
#include <OpenThreads/Block>
#include <iostream>
#include <string>

OpenThreads::Atomic g_ticketCounts(150);

class TicketSellThread : public OpenThreads::Thread
{
public:
    TicketSellThread(const std::string& threadName) : _name(threadName){}
    virtual void run()
    {
        for (int i = 0; i < 50; i++)
        {
            //A售完10张票后,释放主线程,同时阻塞自己
            if ( (i == 10) && (_name == std::string("A")) ) 
            {
                _block.release();
                _block.reset();
                _block.block();
            }
            std::cout << _name << " sell " <<  --g_ticketCounts << std::endl;
        }
    }
    void block()
    {
        _block.block();
    }
    void release()
    {
        _block.release();
    }
private:
    std::string _name;
    OpenThreads::Block _block;
};


int main(int argc, char** argv)
{
    TicketSellThread ticketSellThreadA("A");
    ticketSellThreadA.start();

    TicketSellThread ticketSellThreadB("B");
    ticketSellThreadB.start();

    ticketSellThreadA.block();  //阻塞主进程

    TicketSellThread ticketSellThreadC("C");
    ticketSellThreadC.start();


    while(ticketSellThreadB.isRunning())
        OpenThreads::Thread::YieldCurrentThread();

    while(ticketSellThreadC.isRunning())
        OpenThreads::Thread::YieldCurrentThread();

    ticketSellThreadA.release();    //B和C都卖完以后,再释放A

    while(ticketSellThreadA.isRunning())
        OpenThreads::Thread::YieldCurrentThread();

    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值