线程阻塞的一种情况

    阻塞状态是正在运行的线程遇到某个特殊情况。例如,延迟、挂起、等待I/O操作完成等。 进入阻塞状态的线程让出CPU,并暂时停止自己的执行。线程进入阻塞状态后,就一直等待,直到引起阻塞的原因被消除,线程又转入就绪状态,重新进入就绪队列排队。
    例如:线程A等待线程B的数据,线程B等待线程A的数据,互相等待,就会陷入阻塞,这也是一种线程阻塞。
下面的例子:假设线程A获得了mutex锁,这时另外一个线程试图wakeup线程A,也想获取mutex锁并尝试加锁。
由于两者共用同一把锁,如果线程B wake up命令发的过快,将会频繁的加锁和解锁,而此时线程A可能已经锁住,那么线程B的加锁行为就可能导致线程B阻塞等待。
线程A:
static void* s_NetLink_Connection_Thread(void* arg)
{
  
    while(1)
    {
        pthread_mutex_lock(&ConnectionTestThreadInfo .mutex);
        if(!app_test_connection_thread_ready)
        {
            app_test_connection_thread_ready= true;
         }
     
        pthread_cond_wait(&ConnectionTestThreadInfo.cond, &ConnectionTestThreadInfo.mutex);

        switch( g_AppConnectionTestThreadCmd )
        {
            case ConnectionTestStart:
			     ..................
				 break;
				
            default:
                break;
				
        }

        pthread_mutex_unlock(&ConnectionTestThreadInfo .mutex);
    }

}
线程B:
RETURN_TYPE B_NetLink_Wakeup_Connection_Cmd( ConnectionTestThreadCmd_e cmd )
{
    pthread_mutex_lock(&ConnectionTestThreadInfo .mutex);
    g_AppConnectionTestThreadCmd = cmd;
    pthread_cond_broadcast( &ConnectionTestThreadInfo.cond );
    pthread_mutex_unlock( &ConnectionTestThreadInfo .mutex);
    return SYS_NOERROR;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值