C#using语句

我真的想把这个弄出来.请看下面的代码
using (DataTable resultTable = DBUtility.GetSingleDBTableResult(connectionString,"SELECT * FROM MyDBTable")) {
    List<string> resultsList = new List<string>();
    foreach (DaTarow daTarow in resultTable.Rows) {
        resultsList.Add(daTarow[0].ToString());
    }
    return resultsList;
}

数据表是否处理?有人可以解释这是如何转换为try / catch / finally块的吗? MSDN声明如果发生异常,仍会调用dispose方法但是return语句呢?

或者我应该使用下面的代码

List<string> resultsList = new List<string>();
using (DataTable resultTable = DBUtility.GetSingleDBTableResult(connectionString,"SELECT * FROM MyDBTable")) {
    foreach (DaTarow daTarow in resultTable.Rows) {
        resultsList.Add(daTarow[0].ToString());
    }
}
return resultsList;

可能应该使用第二个,但我只需要启蒙:).请解释.谢谢.

解决方法

using语句只是语法糖,它被转换为try / finally块.从代码开始,这里是C#编译器如何将using块转换为try / finally块.
try
        {
            DataTable resultTable = DBUtility.GetSingleDBTableResult(connectionString,"SELECT * FROM MyDBTable");
            List<string> resultsList = new List<string>();
            foreach (DaTarow daTarow in resultTable.Rows)
            {
                resultsList.Add(daTarow[0].ToString());
            }
            return resultsList; 
        }
        finally
        {
            resultTable.dispose();
        }

正如您从代码中看到的那样,无论return语句如何,resultTable都会被放置. using块仅确保对象在范围之后被释放.

您的第一个代码对我来说没问题,无需更改.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...