私はあなたがこの拡張メソッドを持ち歩く場合は、より良いパフォーマンスを得ることができると思う:
public static Type GetUnderlyingType(this MemberInfo member)
{
switch (member.MemberType)
{
case MemberTypes.Event:
return ((EventInfo)member).EventHandlerType;
case MemberTypes.Field:
return ((FieldInfo)member).FieldType;
case MemberTypes.Method:
return ((MethodInfo)member).ReturnType;
case MemberTypes.Property:
return ((PropertyInfo)member).PropertyType;
default:
throw new ArgumentException
(
"Input MemberInfo must be if type EventInfo, FieldInfo, MethodInfo, or PropertyInfo"
);
}
}
はどのMemberInfo
だけでなく、PropertyInfo
のために働く必要があります。あなたはそれ自体が嘘つきのタイプではない(しかし返品のタイプ)ので、そのリストからMethodInfo
を避けることができます。あなたのケースでは
:
foreach (MemberInfo memberInfo in membersInfo)
{
foreach (object attribute in memberInfo.GetCustomAttributes(true))
{
if (attribute is ReportAttribute)
{
if (((ReportAttribute)attribute).FriendlyName.Length > 0)
{
treeItem.Items.Add(new TreeViewItem() { Header = ((ReportAttribute)attribute).FriendlyName });
}
}
//if memberInfo.GetUnderlyingType() == specificType ? proceed...
}
}
これはデフォルトでBCLの一部となっていなかった私はなぜだろうか。
ええ、 'MemberInfo [] membersInfo ='は悪い兆候です。私が 'var'を好む理由の1つ - 間違ったことが少ないこと。 –
素晴らしい、ありがとうダニエル。 – GrandMasterFlush