windows的UI程序都是消息驱动的,所以出现界面卡死,思考的方向是消息循环是不是能出现问题了。下面分析windows程序界面卡死的几个可能的原因:
-
主线程(UI线程)出现死循环。
如果主线程出现死循环,那么windows将不能从消息队列中取出消息,并进行处理,所以出现卡死现象。为了验证是这个原因导致界面卡死,打开任务管理器,如果该进程的cpu使用率一直保持非零,比如一直保持在3%,那么界面卡死的原因是主线程死循环了。
-
主线程和其他的线程由于资源或者锁争夺,出现了死锁。
如果主线程由于跟其他的线程由于争夺资源或者锁,出现了死锁,那么主线程会一直等待资源或者锁,导致主线程不能继续往下执行,分发和处理消息,所以出现卡死。这种情况下,任务管理器中这个进程的cpu使用率一般是0,也有意外是除这个线程外,其他的线程也在运行,耗费cpu。所以最好的办法是使用调试器,挂载在这个进程上,观察这个进程的各个线程调用栈,观察线程等待的资源等。
-
进程被调试挂载了,调试器在一个断点处断下。
这种情况出现的非常少,只有在调试一个程序的时候才会出现。
-
程序有GDI对象泄漏,导致界面卡死。
对于这种情况。通过观察任务管理器的GDI数据可以发现问题。首先任务管理器的“查看”->“选择列”出现如下的界面,选择GDI对象。这样在任务管理器中就可以看到进程的GDI对象数目了。如果GDI对象数达到千数量级,那么很有可能是这个原因。
以上,只是我遇到的界面卡死的原因,可能有不足之处,广大网友多多见谅。