>我正在尝试创建一个将eUsers list对象映射到用户列表对象的函数。它实际上会映射一些属性,但是当propertyInfo.Name == "UserName"
时,它会在以下行上抛出一个AmbiguousMatchException
:
typeof(User)
.GetProperty(ePropertyInfo.Name, BindingFlags.IgnoreCase | BindingFlags.Instance | BindingFlags.Public | BindingFlags.SetField)
.SetValue(user, ePropertyInfo.GetValue(currentEUser));
我测试了一下,它似乎是由 GetProperty 方法触发的。我不太确定是什么原因造成的。这是完整的功能:
private List<User> ConvertEUsersToUsers(List<eUser> eUsers)
{
List<User> users = new List<User>();
User user = null;
IList<PropertyInfo> eUserProps = new List<PropertyInfo>(eUsers.FirstOrDefault().GetType().GetProperties());
IList<PropertyInfo> userProps = typeof(User).GetProperties();
foreach (eUser currentEUser in eUsers)
{
user = new User();
foreach (PropertyInfo ePropertyInfo in eUserProps)
{
foreach (PropertyInfo propertyInfo in userProps)
{
if (propertyInfo.Name == ePropertyInfo.Name)
{
if (ePropertyInfo.CanWrite)
{
typeof(User)
.GetProperty(ePropertyInfo.Name, BindingFlags.IgnoreCase | BindingFlags.Instance | BindingFlags.Public | BindingFlags.SetField)
.SetValue(user, ePropertyInfo.GetValue(currentEUser));
}
break;
}
}
}
users.Add(user);
}
return users;
}
编辑:
以下是用户和 eUser 类的一部分:
[Serializable]
[Application(7)]
[Table("Users")]
public partial class User : MembershipUser, IPrincipal, IIdentity, IEntity, IIdNameClass {
[Column("Name")]
public new EntityField UserName { get; set; }
}
[Table("Users")]
public class eUser : User
{
[NotMapped]
public Boolean selected { get; set; }
public new UserTypes UserType { get; set; }
public eUser() : base()
{
selected = false;
}
}
User
类上声明UserName
时,通过使用 new
关键字,在其中一个基类中隐藏名为 UserName
的属性。这意味着实际上有多个称为UserName
的属性:来自其中一个基类的原始属性,以及User
中的新属性。这就是导致AmbiguousMatchException
的原因。
尝试使用 BindingFlags.DeclaredOnly
标志仅获取在相关类型上声明的属性:User
。