[英]C# Covariance issue
我有一個linq-to-sql生成的域實體,我將其轉換為正確的接口,如下所示:
public IEnumerable<IApplication> GetApplications()
{
using (var dc = new LqDev202DataContext())
{
return dc.ZApplications.Cast<IApplication>().ToList();
}
}
但是,我重命名了linq-to-sql表,卻沒有碰到我的局部類,並且代碼仍在編譯。
列表中的元素數量正確,但是它們都為空。
我是否需要編寫一個輔助方法來確保它可以正常工作,或者在.net 3.5中是否存在編譯時安全的簡單內置方法?
如果需要,您還可以使用此方法進行轉換轉換:
public static IEnumerable<TDest> CastAll<TItem, TDest>(this IEnumerable<TItem> items)
{
var p = Expression.Parameter(typeof(TItem), "i");
var c = Expression.Convert(p, typeof(TDest));
var ex = Expression.Lambda<Func<TItem, TDest>>(c, p).Compile();
foreach (var item in items)
{
yield return ex(item);
}
}
來自http://adventuresdotnet.blogspot.com/2010/06/better-more-type-safe-alternative-to.html
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.