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被人忽略的用法二(问题的解决)
- Using被人忽略的用法二(问题的解决)
- Using被人忽略的用法
- SourceTree 解决文件名忽略大小写的问题
- Trim容易被人忽略的一个用法
- mysql容易被忽略的用法
- linux cat命令被忽略的用法
- 容易忽略的问题
- 忽略的问题
- GeekOS源代码编译时的packed属性被忽略问题的解决
- java容易被人忽略的一些小问题
- 一些经常被忽略的细节性问题(一)
- 容易被忽略的问题1
- 软件设计容易被忽略的问题
- android一些容易被忽略的问题
- TryParse 容易被忽略的问题
- Duilib 一些可能被忽略的问题
- jQuery那些容易被忽略的问题
- using 语句的用法
- 关于C语言的图形编程
- PCI总线
- 3D显示器成像原理
- BusyBox 简化嵌入式 Linux 系统
- td内有图片和文字,如何都垂直居中
- Using被人忽略的用法二(问题的解决)
- KTV桌面投影游戏机
- JMS入门(五)--消息头
- 恢复db_recovery_file_dest_size参数为默认值“0”方法
- 李建忠:链接的力量
- Ajax入门实例----HelloWorld附源码详细注释
- System.Web.HttpRequestValidationException解决方法
- <数据采集与过程监控系统>摘要
- 如何阅读一款游戏引擎