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

8 篇文章 0 订阅

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




  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值