Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2358606
  • 博文数量: 527
  • 博客积分: 10343
  • 博客等级: 上将
  • 技术积分: 5565
  • 用 户 组: 普通用户
  • 注册时间: 2005-07-26 23:05
文章分类

全部博文(527)

文章存档

2014年(4)

2012年(13)

2011年(19)

2010年(91)

2009年(136)

2008年(142)

2007年(80)

2006年(29)

2005年(13)

我的朋友

分类: WINDOWS

2011-04-08 22:37:56

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

这在.NET编程中是一个常见的错误类型, 即忘记释放那些代表着非内存资源的, 实现了IDispose接口的类。垃圾收集管不了这事。要想及时释放,还得手工进行, 一个方便的语法是using, 可以保证即使在抛出异常的情况下也会自动调用 IDispose的Dispose方法.
阅读(1149) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~