0

我只是想玩一些东西。我做了一种 OR/M 类型的映射器,因为我使用的是反射,所以性能很慢。我怎样才能加快速度或使用更好、更有效的方法?

我有一个带有命名参数的自定义属性并允许多个我然后使用反射来:

  • 获取包含自定义属性修饰的属性
  • 对于找到的每个属性,获取自定义属性数据
  • 对于每个自定义属性数据,获取命名参数

然后我检查命名参数 memberinfo 名称以查看它是否与属性的相关命名参数匹配,如果匹配,它会获取为该命名参数设置的值,最后从 dataReader 读取该命名参数值的数据并使用 . SetValue 将从读取器读取的值设置为属性。

这是一些代码(以任何方式都不完整),希望有人能告诉我如何获得性能改进。运行它 10,000 次(在此之前首次调用 JIT excersize 等......)给了我这些平均时间:

3.79ms

以手动方式进行(即从 DB 到 DTO 的硬编码映射):0.05ms

我知道这就像“另一个 OR/M”——但它并不完全是那样,它比任何东西都更适合我。

private T Populate<T>(IDataReader reader) where T : class, new()
{ 
   T val = new T();

            if (reader != null && !reader.IsClosed)
            {

                var propsWithSQLColumnNameAttributes = typeof(T).GetProperties(BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Static).Where(prop => Attribute.IsDefined(prop, typeof(SQLColumnNameAttribute)) && prop.CanWrite && prop.GetSetMethod() != null);

                foreach (var currentProperty in propsWithSQLColumnNameAttributes)
                {   
                    foreach (var currentAttributeForProperty in currentProperty.GetCustomAttributesData())
                    {
                        string currentAttribParamValue = null;
                        foreach (var currentNamedArgument in currentAttributeForProperty.NamedArguments)
                        {
                            if (String.Equals(currentNamedArgument.MemberInfo.Name, SQLColumnNameAttribute.PropertyNames.DataColumnNamePropertyName, StringComparison.OrdinalIgnoreCase))
                            {
                                currentAttribParamValue = currentNamedArgument.TypedValue.Value == null ? null : currentNamedArgument.TypedValue.Value.ToString();


                                if (reader.DoesFieldExist(currentAttribParamValue))
                                {
                                    var dbRecordValue = reader[currentAttribParamValue] == DBNull.Value ? null : reader[currentAttribParamValue];

                                    currentProperty.SetValue(val, dbRecordValue, null);
                                }
                                break;
                            }
                        }
                    }
                }
            }

            return val;
}

不是最好的代码,但无论如何,性能是这里的问题,并且想知道如何改进它,或者通过使用不同的反射方法,或者使用的排序和算法类型不正确

非常感谢 - 我希望这个问题有意义。

4

1 回答 1

2

看看这个页面http://www.codeproject.com/Articles/503527/Reflection-optimization-techniques看看它是否对你有帮助。它谈到了许多场景中的反射优化,一旦你想学习,这可能是一个很好的资源。

于 2013-01-05T14:51:24.480 回答