在程序中我们通常用到锁机制,但是我们有时候无意之中可能地方存在思索,那么我们如何快速的定位到思索的位置呢?
首先第一次问题出现在我们眼前,什么时候我们想到时死锁问题导致的现象呢!
其实死锁的现象很明显,就是系统启动正常,但是应用程序卡死,这个时候大概率就是死锁了,如果系统挂死,这个时候就是系统或者硬件出现问题了,这个时候我们就应该用串口查看打印,看看该死在哪里,我们今天先不说这种情况,我们今天只看应用程序挂死的情况,说会之前的那一句,程序卡死一定是有地方有互斥锁没有释放,我们先来看看下面这个简单的例子:
#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;