导读: 在多线程编程过程中,不仅仅要解决数据访问的同步与互斥,还要注意多线程的死锁问题,而造成多线程死锁的原因大概可以归咎于系统资源不足、进程推进顺序不当或者资源分配不当等问题。有什么方法可以避免多线程死锁的形成吗?请看下文。
一、死锁原因与形成条件: 死锁形成的原因: 1、系统资源不足;
2、进程(线程)推进的顺序不恰当; 3、资源分配不当。
从编程经验上来讲,形成死锁的一般原因有以下几种: 1、个人使用锁的经验差异。 2、程序模块使用锁的差异。 3、工程代码版本之间的差异。 4、工程代码分支之间的差异。
5、修改代码和重构代码带来的差异。 死锁形成的条件:
1、互斥条件:所谓互斥就是进程在某一时间内独占资源。
2、请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
3、不剥夺条件:进程已获得资源,在末使用完之前,不能强行剥夺。 4、循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
二、常见死锁形成的场景
死锁形成的常见情况有以下几种: 1、忘记释放锁:
01void data_process()02{03EnterCriticalSection();04if(/* error happens, forget LeaveCriticalSection */)05return;06LeaveCriticalSection();07}复制代码void data_process(){EnterCriticalSection();if(/* error happens, forget LeaveCriticalSection */)return;LeaveCriticalSection();}
因篇幅问题不能全部显示,请点此查看更多更全内容