如何使用HyperDescriptor来加速转换?

时间:2013-02-10 08:50:34

标签: c# asp.net generics .net-3.5 datatable

我有一个对象列表如下:

List<UserTransactionDTO>

我希望将此列表转移到Datatable

我搜索并找到以下链接:

Convert generic List/Enumerable to DataTable?

它适用于我,但我不知道如何实现HyperDescriptor以使其更快。是否有一些dll可以使用?


我只是在上一个链接中使用以下代码,它工作正常:

public static DataTable ToDataTable<T>(this IList<T> data)
{
    PropertyDescriptorCollection props =
        TypeDescriptor.GetProperties(typeof(T));
    DataTable table = new DataTable();
    for(int i = 0 ; i < props.Count ; i++)
    {
        PropertyDescriptor prop = props[i];
        table.Columns.Add(prop.Name, prop.PropertyType);
    }
    object[] values = new object[props.Count];
    foreach (T item in data)
    {
        for (int i = 0; i < values.Length; i++)
        {
            values[i] = props[i].GetValue(item);
        }
        table.Rows.Add(values);
    }
    return table;        
}

1 个答案:

答案 0 :(得分:3)

很简单。在项目中引用HyperDescriptor库,并在应用程序初始化中为每个类型调用一次,以使每个类型的描述符为“hyper”:

Hyper.ComponentModel.HyperTypeDescriptionProvider.Add(typeof(MyType))

或者,您可以使用我在项目评论中提供的HyperTypeDescriptionProvider版本HyperDescriptor at CodeProject。它解决了我发现的一些问题,包括尝试将类型及其基类型添加到HyperTypeDescriptionProvider时的堆栈溢出问题。如果你这样做,你可以简单地在你的函数中进行Add()调用,并且不会发生坏事,因为具有相同类型的第二次调用不会在我的版本中添加两次类型。在ToDataTable<T>()功能的顶部,添加以下行:

Hyper.ComponentModel.HyperTypeDescriptionProvider.Add(typeof(T))

无论您采用哪种方式,都不要忘记在之前/之后进行基准测试,以确保获得性能优势。

P.S。我非常感谢Marc Gravell他在HyperDescriptor上的工作,我认为它是一种非常漂亮和有用的魔法。