加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C#泛型问题

发布时间:2020-12-15 20:50:42 所属栏目:百科 来源:网络整理
导读:我对泛型有点生疏,尝试做以下事情,但编译器抱怨: protected ListT PopulateCollection(DataTable dt) where T: BusinessBase{ ListT lst = new ListT(); foreach (DataRow dr in dt.Rows) { T t = new T(dr); lst.Add(t); } return lst;} 正如您所看到的,我
我对泛型有点生疏,尝试做以下事情,但编译器抱怨:

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);

还要向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;
}

如果您使用的是.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.这样做的好处是允许你编写不可变类(以及没有无参数构造函数的类),但这意味着你不能在没有“工厂”功能的情况下一般地工作.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读