C#中using在强制资源清理的用法

作者:袖梨 2022-06-25

using 在C#中除了引用命名空间和为命名空间创建别名外,它还可以用做强制资源清理,方法如下:

 代码如下 复制代码

using (SqlConnection connection = new SqlConnection(connectionString)) {     PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);     object val = cmd.ExecuteScalar();     cmd.Parameters.Clear();     return val; }

上面代码完全等效于

 代码如下 复制代码

SqlConnection connection = new SqlConnection(connectionString); try{     PrepareCommand(cmd, connection, null, cmdType,cmdText, commandParameters);     object val = cmd.ExecuteScalar();     cmd.Parameters.Clear();     return val; } finally{     connection.disponse(); }

实际上,我们用using()并编译后,编译器生成的也是try{}finally{}代码,生成的代码中需要执行disponse(),因此在using()中创建的对象必需实现Idisponse接可,不然是无法通过编译的。

既然了解了using()的真相,我们应该知道什么时候用using()了吧。为也再进一步了解我们何时用using,何时用try,我们看看下面两段代码(高手可以跳过啦!!)

 代码如下 复制代码

using (SqlConnection connection = new SqlConnection(connectionString)) {     PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters);     object val = cmd.ExecuteScalar();     cmd.Parameters.Clear();     return val; }

这段和上面的第一段代码相同,由于cmd的结果已经被保存到object val里,所以然后释放connection对结果并不会有任何影响。

再来看看下一再using的代码

 代码如下 复制代码

try {     PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);     SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);     cmd.Parameters.Clear();     return rdr; } catch {     conn.Close();     throw; }

这时就不能再用using 自动释放connection了,因为rdr的操作需要打开数据库连接的,如果自动释放connection连接会导致rdr无法操作。何时用using可以用以下规则来确定:

1、无论代码成功与否都释放对象时;

2、对象实现Idisponse接口;

3、只有一个对象需要释放。

相关文章

精彩推荐