今天写的这篇博客主要是针对大家对我的上一篇博客的问题的解答,争议最大的事情也就是Using对象的释放的问题。好了废话不多说直接进入主题。
问题一:问个问题 在操作数据库时,使用using,怎么捕捉到异常,比如突然断网了,数据库操作失败(增删查改)?
关于这个问题我觉得大家看一段反编译的代码,我想大家就会明白:
比如这样一段代码:
using (SqlConnection conn = new SqlConnection()) { conn.Open(); }
IL代码可为:
// Code size 42 (0x2a) .maxstack 2 .locals init ([0] class [System.Data]System.Data.SqlClient.SqlConnection conn, [1] bool CS$4$0000) IL_0000: nop IL_0001: newobj instance void [System.Data]System.Data.SqlClient.SqlConnection::.ctor() IL_0006: stloc.0 .try { IL_0007: nop IL_0008: ldloc.0 IL_0009: callvirt instance void [System.Data]System.Data.Common.DbConnection::Open() IL_000e: nop IL_000f: ldstr "Exception!!" IL_0014: newobj instance void [mscorlib]System.Exception::.ctor(string) } // end .try finally { IL_001a: ldloc.0 IL_001b: ldnull IL_001c: ceq IL_001e: stloc.1 IL_001f: ldloc.1 IL_0020: brtrue.s IL_0029 IL_0022: ldloc.0 IL_0023: callvirt instance void [mscorlib]System.IDisposable::Dispose() IL_0028: nop IL_0029: endfinally } // end handler
这是一段用IL进行反编译的一段代码,里面的东西大多我也看不太懂,但是里面的框架大家可以清楚的看到try........finally,也就是说Using根本就没有抛出异常的功能,他只可以释放对象,所以这就是真正的Using。
问题二:你释放的是SqlCommand,判断的是SqlConnection。
对,我在我上一篇博客里面写的错误的例子,的确和上面的问题写的是一样的,我释放的对象根本就是错的又怎么可以释放呢。所以我想感谢给我评论和指点我的人
下面的这段代码是我上篇博客Using被人忽略的用法 一个评论:
using (SqlConnection conn = new SqlConnection(connstring))
{
conn.Open();
using (SqlCommand cmd = new SqlCommand(cmdstring, conn))
{
cmd.ExecuteNonQuery();
}
}
没错就是这样,一段小小的代码比谁说的都清楚,里面用的是一个Using的用法的嵌套,就很容易的轻易的将我的所写的问题的给解决了,在这里我只想说一句 “牛啊,牛人啊”
作者:李志华
博客连接 :Using被人忽略的用法二(问题的解决)