Using被人忽略的用法二(问题的解决)

来源:互联网 发布:澳大利亚博士 知乎 编辑:程序博客网 时间:2024/06/16 15:16

          今天写的这篇博客主要是针对大家对我的上一篇博客的问题的解答,争议最大的事情也就是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被人忽略的用法二(问题的解决)