C# 协方差问题
我有一个linq到sql生成的域实体,我将其转换到适当的接口,如下所示:C# 协方差问题,c#,linq,linq-to-sql,c#-3.0,covariance,C#,Linq,Linq To Sql,C# 3.0,Covariance,我有一个linq到sql生成的域实体,我将其转换到适当的接口,如下所示: public IEnumerable<IApplication> GetApplications() { using (var dc = new LqDev202DataContext()) { return dc.ZApplications.Cast<IApplication>().ToList(); } }
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);
}
}
我不认为这是一个协方差问题。我想这是由重命名引起的LINQ到SQL问题。