阻塞状态是正在运行的线程遇到某个特殊情况。例如,延迟、挂起、等待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;
}