在 using 块的中间返回
比如:
using (IDisposable disposable = GetSomeDisposable())
{
//.....
//......
return Stg();
}
我认为这不是返回语句的合适位置,是吗?
Something like:
using (IDisposable disposable = GetSomeDisposable())
{
//.....
//......
return Stg();
}
I believe it is not a proper place for a return statement, is it?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
正如其他几位人士普遍指出的那样,这不是问题。
唯一会导致问题的情况是,如果您在 using 语句中间返回并另外返回 in using 变量。 但话又说回来,即使您没有返回并且只是保留对变量的引用,这也会给您带来问题。
同样糟糕
As several others have pointed out in general this is not a problem.
The only case it will cause you issues is if you return in the middle of a using statement and additionally return the in using variable. But then again, this would also cause you issues even if you didn't return and simply kept a reference to a variable.
Just as bad
完全没问题。
您显然认为它
被盲目地翻译成:
不可否认,这将是一个问题,并且会使
using
语句变得毫无意义 --- 这就是为什么这不是确实如此。编译器确保在控制离开块之前处理对象——无论它如何离开块。
It's perfectly fine.
You are apparently thinking that
is blindly translated into:
Which, admittedly, would be a problem, and would make the
using
statement rather pointless --- which is why that's not what it does.The compiler makes sure that the object is disposed before control leaves the block -- regardless of how it leaves the block.
绝对没问题——完全没问题。 为什么你相信这是错误的?
using 语句只是 try/finally 块的语法糖,正如 Grzenio 所说,从 try 块返回也可以。
将计算返回表达式,然后执行finally 块,然后该方法将返回。
It's absolutely fine - no problem at all. Why do you believe it's wrong?
A using statement is just syntactic sugar for a try/finally block, and as Grzenio says it's fine to return from a try block too.
The return expression will be evaluated, then the finally block will be executed, then the method will return.
这将完全正常工作,就像在
try{}finally{}
中间返回一样This will work perfectly fine, just as returning in the middle of
try{}finally{}
这是完全可以接受的。 using 语句确保 IDisposable 对象无论如何都会被释放。
来自 MSDN:
That is totally acceptable. A using statement ensures the IDisposable object will be disposed no matter what.
From MSDN:
下面的代码显示了
using
的工作原理:输出:
释放函数在 return 语句之后、函数退出之前被调用。
The code bellow shows how
using
is working:Output:
The disposed are called after the return statement but before the exit of the function.
也许这并不是 100% 正确,这是可以接受的......
如果您碰巧嵌套使用并从嵌套使用中返回,则可能不安全。
以此为例:
我传入一个 DataTable 以将其输出为 csv。 当 return 位于中间时,它将所有行写入流,但输出的 csv 总是缺少一行(或多行,具体取决于缓冲区的大小)。 这告诉我有些东西没有正确关闭。
正确的方法是确保之前的所有使用都得到正确处理:
Perhaps it isn't 100% true that this is acceptable...
If you happen to be nesting usings and returning from within a nested one, it might not be safe.
Take this as an example:
I was passing in a DataTable to be outputted as csv. With the return in the middle, it was writing all the rows to the stream, but the outputted csv was always missing a row (or multiple, depending on the size of the buffer). This told me that something wasn't being closed properly.
The correct way is to make sure all the previous usings are disposed properly: