C# foreach
循环变量重用:一个不必要的陷阱
在C#中使用lambda表达式或匿名方法时,可能会出现修改后的闭包访问陷阱。foreach
循环中变量的重用加剧了这个问题。
编译器通常在循环体外部声明循环变量,如修改后的闭包示例所示:
<code class="language-C#">string s; while (enumerator.MoveNext()) { s = enumerator.Current; ... }</code>
这与在循环内声明变量的预期不同:
<code class="language-C#">while (enumerator.MoveNext()) { string s; s = enumerator.Current; ... }</code>
外部变量声明加剧了修改后的闭包访问问题,因为它为变量创建了更长的作用域。在foreach
循环内声明的变量无法在循环外部访问。
编译器决定重用循环变量是在引入lambda表达式和匿名方法之前做出的。因此,当时并没有充分考虑变量重用的潜在陷阱。
在C# 5中,这个设计缺陷将通过一个重大更改来解决。循环变量将在逻辑上放置在循环体内部,确保每次闭包都获得一个新的副本。此更改消除了foreach
循环的修改后的闭包访问陷阱。
虽然此修复是一个受欢迎的改进,但在使用旧版代码或不支持此修复的旧版C#版本时,仍然需要注意此问题。
以上是为什么C#'s' foreach”循环变量可重用会导致关闭问题?的详细内容。更多信息请关注PHP中文网其他相关文章!