近期项目中使用winform做了一个功能界面,需要定时获取目录中的文件并将文件存储到指定路径中。在测试中发现程序运行几天后异常崩溃,各种分析后发现进程的句柄数量异常导致,句柄数量一直在增长,没有下降,每个进程都有句柄数量的限制,达到一定数量后,进程就会崩溃;
在网上各种搜,有的说是使用Timer引起的,有的说是Control.BeginInvoke引起的,都没啥具体解释和解决方案;最终只能一块块的代码排查,显示排查Timer,将Timer去掉后句柄数量依然增长,说明不是Timer引起的问题;循环调用Control.BeginInvoke,确实会引起句柄数量增长,但是我的代码极少去调用Control.BeginInvoke,排除此问题;后来发现去掉调用外部dll库,句柄数量不再异常增长,确定是dll库的原因;
打开dll库源码,发现其中有一个creatEvent句柄没有释放,无语啊,释放句柄后重新生成dll库;注册,调用,句柄数量不再持续增长。
经过分析,确定Timer并不会引起句柄数量的异常,要是有句柄数量异常肯定是Timer中的功能模块有问题;control.BeginInvoke确实会引起句柄数量增长,此问题有待进一步研究解决。