写程序的时候为了方便,于是就将日志的显示直接调用控件的一些函数来实现,如InsertItem等。刚开始的时候担心多线程调用的时候会引起资源混乱的问题,于是在调用InsertItem的时候加了锁。但是在点关闭按钮的时候,经常会死锁,会VS 2005调试了一下发现在停在InsertItem,这样百思不得其解。后来发现在点关闭按钮的时候,在等一个线程结束,但是停在InsertItem的时候,正是这个线程调用的。怎么会出现这种情况的呢?
后来去看一了一下InsertItem的实现,原来InsertItem是调用SendMessage向主线程发送消息,让主线程来显示具体的信息。而SendMessage是同步调用的,即等到主线程显示了以后再返回。但是现在主线程正响应关闭按钮在等待这个线程的结束,而线程正在等待SendMessage的返回,于是就造成了死锁。其实这个关不是真正意义上的死锁,而是循环等待。看来多线程操作同一个控件的时候,不是加个锁就能够解决的。