用.NET做一个web service,用到了SQL Server 数据库, 通过 SqlConnection来连接数据库, 测试部门报告说性能测试下出现超时错误, 我写在系统日志中的异常表明是SqlConnection.Open方法失败了, 达到了Max Pool Size, 根本原因是, SqlConnection实现了IDispose接口, 光顾着打开使用, 没记着应尽的义务: Close.
这在.NET编程中是一个常见的错误类型, 即忘记释放那些代表着非内存资源的, 实现了IDispose接口的类。垃圾收集管不了这事。要想及时释放,还得手工进行, 一个方便的语法是using, 可以保证即使在抛出异常的情况下也会自动调用 IDispose的Dispose方法.
阅读(1149) | 评论(0) | 转发(0) |