死锁如何定位

在程序中我们通常用到锁机制,但是我们有时候无意之中可能地方存在思索,那么我们如何快速的定位到思索的位置呢?

首先第一次问题出现在我们眼前,什么时候我们想到时死锁问题导致的现象呢!

其实死锁的现象很明显,就是系统启动正常,但是应用程序卡死,这个时候大概率就是死锁了,如果系统挂死,这个时候就是系统或者硬件出现问题了,这个时候我们就应该用串口查看打印,看看该死在哪里,我们今天先不说这种情况,我们今天只看应用程序挂死的情况,说会之前的那一句,程序卡死一定是有地方有互斥锁没有释放,我们先来看看下面这个简单的例子:

#include<stdio.h>
#include<pthread.h>

pthread_mutex_t g_pthMutex_iic;

typedef enum 
{
	SN1 = 0x53,
	CODE1,
	MAC1,
	SN2,
	CODE2,
	MAC2,
	NONE,
}TYPE;

int write_iic(int phy_address)
{
	printf("fun = %s,line =%d\n",__FUNCTION__,__LINE__);
	return 0;
}

int write_test(int write_address)
{
	pthread_mutex_lock(&g_pthMutex_iic);
	switch(write_address)
	{
		case SN1:
			write_iic(write_address);
			pthread_mutex_unlock(&g_pthMutex_iic);
			break;
		case MAC1:
			write_iic(write_address);
			pthread_mutex_unlock(&g_pthMutex_iic);
			break;
上一篇:线程安全和可重入函数


下一篇:经典进程同步问题