快速业务通道

利用using和try-finally来释放资源

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-04-12

       关于.Net资源释放问题,也就是对于非内存的资源,最好使用IDisposable接口提供的Dispose来释放。
       很明显,Dispose方法是一个外部方法,系统并不会帮你调用。为了尽早释放对象所占用的资源,所以需要保证Dispose方法能尽早被执行。那么在.Net中提供了一个比较简便的方法,就是对于实现了IDisposable接口的类型对象提供了using语句。


   就操作一个数据库这个例子来说,使用using语句可以如下:
    using( SqlConnection sqlConn = new SqlConnection( yourConnectionString ) )

    {         sqlConn.Open(); //Open connection            //Operate DB here using "sqlConn"         sqlConn.Close(); //Close connection     }
但是有时候当多个对象需要释放的候,例如:
    SqlConnection sqlConn = new SqlConnection( yourConnectionString );     SqlCommand sqlComm = new SqlCommand( yourQueryString, sqlConn );     using(sqlConn as IDisposable)     using(sqlComm as IDisposable)     {         sqlConn.Open(); //Open connection            sqlComm.ExecuteNonQuery(); //Operate DB here     }
       这时候要特别注意,需要确保在发生异常的情况下,所有对象都能正常释放。显然,这段程序块,当构造“sqlComm”对象发生异常,会造成“sqlConn”对象无法及时被释放。虽说构造函数内部很少发生异常,或者说编写程序的时候要尽量避免从构造函数内向外散发异常。不过这里所说的意思是,要尽量把需要释放的对象放到using或者try-catch程序块,并作局部的异常处理,避免异常造成有些对象没有被释放。那么改进的方法,例如可以如下。     using( SqlConnection sqlConn = new SqlConnection( yourConnectionString ) )     using( SqlCommand sqlComm = new SqlCommand( yourQueryString, sqlConn ) )     {         try         {             sqlConn.Open(); //Open connection             sqlComm.ExecuteNonQuery(); //Operate DB here         }         catch( SqlException err )         {             MessageBox.Show( err.Message );         }         catch( Exception err )         {             MessageBox.Show( err.Message );         }     }
(如上,即使在构造“sqlComm”出现异常,也会释放&l

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号