我对泛型有点生疏,尝试做以下事情,但编译器抱怨:
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; }
正如您所看到的,我正在尝试将表的内容转储到对象中(通过将DaTarow传递给构造函数),然后将对象添加到集合中.它抱怨T不是它所知道的类型或命名空间,并且我不能在非泛型声明中使用它.
这不可能吗?
解决方法
有两个大问题:
>您不能指定带参数的构造函数约束
>您的方法目前不是通用的 – 它应该是PopulateCollection< T>而不是PopulateCollection.
你已经有了T:BusinessBase的约束,所以为了解决第一个问题,我建议你在BusinessBase中添加一个抽象(或虚拟)方法:
public abstract void PopulateFrom(DaTarow dr);
您的方法可以成为:
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; }
如果您使用的是.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(); }
或者,您可以将其作为扩展方法本身(同样,假设.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(); }
然后你的来电者会写:
table.ToList(row => new Whatever(row));
这假设你回到让构造函数采用DaTarow.这样做的好处是允许你编写不可变类(以及没有无参数构造函数的类),但这意味着你不能在没有“工厂”功能的情况下一般地工作.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。