Ang*_*ker 3 c# generics collections
我对泛型有点生疏,尝试做以下事情,但编译器抱怨:
protected List<T> PopulateCollection(DataTable dt) where T: BusinessBase
{
List<T> lst = new List<T>();
foreach (DataRow dr in dt.Rows)
{
T t = new T(dr);
lst.Add(t);
}
return lst;
}
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,我正在尝试将表的内容转储到对象中(通过将DataRow传递给构造函数),然后将对象添加到集合中.它抱怨T不是它所知道的类型或命名空间,并且我不能在非泛型声明中使用它.
这不可能吗?
Jon*_*eet 21
有两个大问题:
PopulateCollection<T>代替PopulateCollection.你已经有了一个约束T : BusinessBase,所以为了解决第一个问题,我建议你在下面添加一个抽象(或虚拟)方法BusinessBase:
public abstract void PopulateFrom(DataRow dr);
Run Code Online (Sandbox Code Playgroud)
还要添加无参数构造函数约束T.
您的方法可以成为:
protected List<T> PopulateCollection(DataTable dt)
where T: BusinessBase, new()
{
List<T> lst = new List<T>();
foreach (DataRow dr in dt.Rows)
{
T t = new T();
t.PopulateFrom(dr);
lst.Add(t);
}
return lst;
}
Run Code Online (Sandbox Code Playgroud)
如果您使用的是.NET 3.5,则可以使用以下扩展方法使其略微简单DataTableExtensions:
protected List<T> PopulateCollection<T>(DataTable dt)
where T: BusinessBase, new()
{
return dt.AsEnumerable().Select(dr =>
{
T t = new T();
t.PopulateFrom(dr);
}.ToList();
}
Run Code Online (Sandbox Code Playgroud)
或者,您可以将其作为扩展方法本身(同样,假设.NET 3.5)并传入一个函数来返回实例:
static List<T> ToList<T>(this DataTable dt, Func<DataRow dr, T> selector)
where T: BusinessBase
{
return dt.AsEnumerable().Select(selector).ToList();
}
Run Code Online (Sandbox Code Playgroud)
然后你的来电者会写:
table.ToList(row => new Whatever(row));
Run Code Online (Sandbox Code Playgroud)
这假设你回到有一个构造函数DataRow.这样做的好处是允许你编写不可变类(以及没有无参数构造函数的类),但这意味着你不能在没有"工厂"功能的情况下一般地工作.
| 归档时间: |
|
| 查看次数: |
816 次 |
| 最近记录: |