Tim*_*uri 3 c# compiler-construction ienumerable virtual yield-return
我正在创建一个基类,它有一个virtual名为"GetBaseAddresses()"的方法.它有一个返回类型IEnumerable<Uri>.yield如果枚举,基类将不会产生任何结果,但派生类可以选择覆盖该方法并返回任意数量的项目.
这是基本方法:
public virtual IEnumerable<Uri> GetBaseAddresses() { }
Run Code Online (Sandbox Code Playgroud)
问题是,这将无法编译.您必须为编译器返回一个值才能满意.所以,因为我想得到一个空的结果,我会回来null,对吧?
public virtual IEnumerable<Uri> GetBaseAddresses() { return null; }
Run Code Online (Sandbox Code Playgroud)
问题在于,如果某人foreach在基类的实例上执行操作,则会因"对象引用未设置..."的运行时错误而崩溃.
所以,回想一下yield return关键字对C#编译器有些神奇...我想出了这个编译器hack(顺便说一下).
public virtual IEnumerable<Uri> GetBaseAddresses()
{
if (false) { yield return new Uri(""); }
}
Run Code Online (Sandbox Code Playgroud)
奇怪的是,即使"if(false){...}"代码被完全编译掉 - 编译器也满意我满足"必须返回一个值"的要求,并且完全符合我的要求 - 也就是说,可以安全枚举的空结果集.
我的问题是 - 如果没有我的编译技巧,有没有办法做到这一点?
usr*_*usr 10
使用空数组,或:
yield break; //end enumeration
Run Code Online (Sandbox Code Playgroud)
从评论中提取svick的想法:
return Enumerable.Empty<Uri>();
Run Code Online (Sandbox Code Playgroud)
这更快,因为Enumerable.Empty总是返回一些空的可枚举的缓存的预分配实例.
小智 9
只需在base方法中返回一个空的枚举.
public virtual IEnumerable<Uri> GetBaseAddresses()
{
return Enumerable.Empty<Uri>();
}
Run Code Online (Sandbox Code Playgroud)
或者,如果您的目标是.NET框架的版本<3.5,则返回一个空列表.
内置数组支持IEnumerable,因此您可以使用:
public virtual IEnumerable<Uri> GetBaseAddresses()
{
return new Uri[0];
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
810 次 |
| 最近记录: |