忽略IDispose接口的类型导致的bug

1187阅读 0评论2011-04-08 slimzhao
分类:WINDOWS

用.NET做一个web service,用到了SQL Server 数据库, 通过 SqlConnection来连接数据库, 测试部门报告说性能测试下出现超时错误, 我写在系统日志中的异常表明是SqlConnection.Open方法失败了, 达到了Max Pool Size, 根本原因是, SqlConnection实现了IDispose接口, 光顾着打开使用, 没记着应尽的义务: Close.

这在.NET编程中是一个常见的错误类型, 即忘记释放那些代表着非内存资源的, 实现了IDispose接口的类。垃圾收集管不了这事。要想及时释放,还得手工进行, 一个方便的语法是using, 可以保证即使在抛出异常的情况下也会自动调用 IDispose的Dispose方法.
上一篇:整理制作电子书技巧(9): PDF中优化大小与图像质量
下一篇:bug of day: solution 文件中项目的build order与并行编译