我正在尝试制作一个将eUsers列表对象映射到用户列表对象的函数。它实际上会映射一些属性,但是当时propertyInfo.Name == "UserName",它将AmbiguousMatchException在下面的行中抛出a :
typeof(User)
.GetProperty(ePropertyInfo.Name, BindingFlags.IgnoreCase | BindingFlags.Instance | BindingFlags.Public | BindingFlags.SetField)
.SetValue(user, ePropertyInfo.GetValue(currentEUser));
Run Code Online (Sandbox Code Playgroud)
我进行了测试,看来它是由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;
}
Run Code Online (Sandbox Code Playgroud)
编辑:
这是User和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;
}
}
Run Code Online (Sandbox Code Playgroud)
UserName在类上进行new声明时UserName,将通过使用关键字隐藏在一个基类中调用的属性User。这意味着实际上有多个属性被称为UserName:一个基类中的原始属性,以及中的新属性User。这是什么原因造成的AmbiguousMatchException。
尝试使用该BindingFlags.DeclaredOnly标志仅获取在有关类型上声明的属性User。
| 归档时间: |
|
| 查看次数: |
114 次 |
| 最近记录: |