gpt4 book ai didi

c# using 语句 with double IDisposable

转载 作者:行者123 更新时间:2023-11-30 20:18:09 25 4
gpt4 key购买 nike

我有以下使用 using 的语句:

using (var reader = data.CreateCommand(sql).ExecuteDataReader())

在这种情况下,data 是内部包含 SqlConnection 的某个对象。 CreateCommand(sql) 函数返回 SqlCommandExecuteDataReader 返回 SqlDataReader。由于 SqlCommandSqlDataReader 都是 IDisposable,那么使用 using 语句时它们都会被释放吗?

现在我是这样做的:

using (var cmd = data.CreateCommand(sql))
using (var reader = cmd.ExecuteDataReader())

但我想知道是否可以如上所述将它们组合起来?

最佳答案

“如果可以将它们组合起来” - 两个 using 完全没问题,因为两者都需要处理。

你可以通过提取到方法中来组合它们:

void RunWithReader(string sql, Action<SQLDataReader> action)
{
using (var cmd = data.CreateCommand(sql))
using (var reader = cmd.ExecuteDataReader())
action(reader);
}

然后你可以使用lambda

RunWithReader("whatever command", reader =>
{
... // while(reader.Read() { ... } - this could also be extracted
});

关于c# using 语句 with double IDisposable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42411723/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com