为什么简单数组和 Linq 会生成 VerificationException:操作可能会破坏运行时稳定性
C# 中非常简单的 ?: 运算符与简单数组和对 Reverse() 的 LINQ(对象)调用相结合,显然足以导致异常“System.Security.VerificationException:操作可能会破坏运行时的稳定性”。 当在以“高”信任运行的 ASP.NET 网站上运行时(请注意,“完全”是默认值)
以下是代码,以及我想出的简单解决方法:
protected void Page_Load(object sender, EventArgs e) {
Repro();
//Workaround();
}
private IEnumerable<string> Repro() {
bool test = true;
string[] widgets = new string[0];
return test ? widgets : widgets.Reverse();
}
private IEnumerable<string> Workaround() {
bool test = true;
string[] widgets = new string[0];
if (test) {
return widgets;
} else {
return widgets.Reverse();
}
}
要将信任级别设置为“高”,必须将以下内容添加到 web.config 文件中:
<trust level="High" originUrl=""/>
解决方法的功能相当于重现问题的有问题的 ?: 运算符。 通过阅读相关文章,我猜测这是一个 C# 编译器错误。 有人知道这是怎么回事吗?
A very simple ?: operator in C#, combined with a simple array and LINQ (to Objects) call to Reverse() is apparently enough to cause the exception "System.Security.VerificationException: Operation could destabilize the runtime." when run on an ASP.NET web site running with "High" trust (note that "Full" is the default)
Here is the code, plus the straightforward workaround that I came up with:
protected void Page_Load(object sender, EventArgs e) {
Repro();
//Workaround();
}
private IEnumerable<string> Repro() {
bool test = true;
string[] widgets = new string[0];
return test ? widgets : widgets.Reverse();
}
private IEnumerable<string> Workaround() {
bool test = true;
string[] widgets = new string[0];
if (test) {
return widgets;
} else {
return widgets.Reverse();
}
}
To set the trust level to "High", the following must be added to the web.config file:
<trust level="High" originUrl=""/>
The workaround is functionality equivalent to the problematic ?: operator that repros the problem. My guess from reading related posts is this is a C# compiler bug. Anyone know what's going on here?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
此行没有问题:
This line does not have the issue:
我发现改变表达式的顺序也可以解决这个问题:
想想看!
I found that changing the order of the expression works around the issue as well:
Go figure!