栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

是否需要手动关闭并处置SqlDataReader?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

是否需要手动关闭并处置SqlDataReader?

尽量避免使用这样的读者:

SqlConnection connection = new SqlConnection("connection string");SqlCommand cmd = new SqlCommand("SELECt * FROM Sometable", connection);SqlDataReader reader = cmd.ExecuteReader();connection.Open();if (reader != null){      while (reader.Read())      {   //do something      }}reader.Close(); // <- too easy to forgetreader.Dispose(); // <- too easy to forgetconnection.Close(); // <- too easy to forget

相反,将它们包装在using语句中:

using(SqlConnection connection = new SqlConnection("connection string")){    connection.Open();    using(SqlCommand cmd = new SqlCommand("SELECt * FROM Sometable", connection))    {        using (SqlDataReader reader = cmd.ExecuteReader())        { if (reader != null) {     while (reader.Read())     {         //do something     } }        } // reader closed and disposed up here    } // command disposed here} //connection closed and disposed here

using语句将确保正确处置对象和释放资源。

如果您忘记了,则将清理工作留给垃圾收集器,这可能需要一段时间。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/568485.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号