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、只有一个对象需要释放。
暗影猎手失落的世界 最新版本v30.118.6.0
下载格里姆瓦勒完全版 安卓版v1.2.0
下载忍者武士暗影格斗无限金币版 安卓版v1.82.1
下载忍者必须死34399账号登录版 最新版v1.0.138v2.0.72
下载创造与魔法免登录版 手机版v1.0.0760
创造与魔法是一款高度自由的沙盒冒险手游,该游戏采用了3D最新
创造与魔法gm版 安卓版v1.0.0760
创造与魔法是一款有英雄互娱运营的一款经营沙盒建造手游,该游戏
创造与魔法变态无敌版 v1.0.0760
创造与魔法是一款3DQ版的沙盒模拟建造手游,在这里玩家需要适
腾讯普通话小镇游戏 安卓版v2.2.5
普通话小镇是由腾讯游戏追梦计划推出发行的模拟经营类型普通学习
海岛村 最新版v1.0
海岛村是一款非常好玩的模拟经营类手游,玩家在游戏中将会有一个