我有一个使用某些FieldInfo对象的方法:
public static T SetFieldValue<T>(this T src, string propName, object value)
{
Type type = typeof(T);
FieldInfo propInfo = type.GetField(propName,
BindingFlags.Instance | BindingFlags.NonPublic);
Type propType = propInfo.FieldType;
var targetType = IsNullableType(propType)
? Nullable.GetUnderlyingType(propType) : propType;
value = Convert.ChangeType(value, targetType);
propInfo.SetValue(src, value);
return src;
}
现在,我需要某种方法从此函数返回的特定FieldInfo中获取PropertyInfo对象,这主要是因为我特别需要PropertyInfo.Name字符串,对此有何想法?
编辑: 这是一些更具体的代码,我使用这种方法来获取两个对象之间的区别:
public static List<Variance> DetailedCompare<T>(this T val1, T val2)
{
List<Variance> variances = new List<Variance>();
FieldInfo[] fi = typeof(T).GetFields(BindingFlags.Instance | BindingFlags.NonPublic);
foreach (FieldInfo f in fi) {
Variance v = new Variance();
v.Prop = f.Name;
v.valA = f.GetValue(val1);
v.valB = f.GetValue(val2);
if (v.valA != null) {
if (!v.valA.Equals(v.valB))
variances.Add(v);
} else if (v.valB != null) {
variances.Add(v);
}
}
return variances;
}
然后,我使用返回的字段来格式化SQL查询,该查询将发送给Web服务,具体来说。但是FieldInfo.Name对象通常类似于k__BackingField或k__BackingField 我需要PropertyInfo.Name,这是正确的名称。 有什么方法可以从FieldInfo对象创建PropertyInfo对象?
答案 0 :(得分:0)
我以前的代码中有这个。
private static PropertyInfo GetInfo(object myObject, string name)
{
return myObject.GetType().GetProperty(name);
}
您可以使用PropertyInfo
msdn https://docs.microsoft.com/en-us/dotnet/api/system.reflection.propertyinfo?view=netframework-4.7.2
如果您想让所有成员成为T
Type type = typeof(T);
MemberInfo[] tempInfo = type.GetMembers();
会员信息 https://docs.microsoft.com/en-us/dotnet/api/system.reflection.memberinfo?view=netframework-4.7.2
答案 1 :(得分:0)
我设法解决了这个问题
public static List<Variance> DetailedCompare<T>(this T val1, T val2, bool pName = false)
{
List<Variance> variances = new List<Variance>();
FieldInfo[] fi = typeof(T).GetFields(BindingFlags.Instance | BindingFlags.NonPublic);
foreach (FieldInfo f in fi) {
Variance v = new Variance();
PropertyInfo prop = default(PropertyInfo);
if (pName) {
prop = typeof(T).GetProperties().Where(p => f.Name.Contains(p.Name)).FirstOrDefault();
}
v.Prop = pName ? (prop != default(PropertyInfo) ? prop.Name : "") : f.Name;
v.valA = f.GetValue(val1);
v.valB = f.GetValue(val2);
if (v.valA != null) {
if (!v.valA.Equals(v.valB))
variances.Add(v);
} else if (v.valB != null) {
variances.Add(v);
}
}
return variances;
}
我所做的是使该方法返回PropertyInfo.Name的可能性。