我得到以下代码生成DLL(示例示例):
public class PluginClass { private string _MyString; public string MyString { get { return _MyString; } set { _MyString = value; RaisePropertyChanged("MyString"); } } public int MyInt; public SpeedGenerator SpeedGenerator1 = new SpeedGenerator(); public GaugeValueGenerator GaugeValueGenerator1 { get; set; } public PluginClass() { GaugeValueGenerator1 = new GaugeValueGenerator(); } }
如你所见,我有4个字段/属性.
1个原始字段(primitive是int / string / bool / etcetc …):MyInt
1个原始属性:MyString
1个对象字段:SpeedGenerator1
1个对象属性:GaugeValueGenerator1
当我解析我的DLL时,我得做一些函数中的代码:WriteProperty
var fields = type.GetFields(BindingFlags.Public | BindingFlags.Instance); var props = type.GetProperties(); foreach (FieldInfo field in fields) { WriteProperty(field.FieldType,field.Name,XXX); } foreach (PropertyInfo prop in props) { WriteProperty(prop.PropertyType,prop.Name,XXX); }
我的问题是关于XXX这是一个布尔值,表明我的字段/属性是否是“原始的”.因此,如果它是一个对象,则必须设置为false.
我摔倒了,因为我尝试了一切,但我无法解决它……
任何帮助将非常感谢!
(我的想法是打电话
var props = propertyType.GetProperties(BindingFlags.Instance | BindingFlags.Public | BindingFlags.DeclaredOnly);
并认为它对于简单/原始类型应该是空的!但是没有…例如在String上,这返回属性Chars(char [])和Length(int)…)
(nb:当然我不想对field / property.Name / FullName做一个字符串操作……就像
if ((propertyType.FullName).Contains("System."))
会非常非常糟糕……并且不准确)
解决方法
为什么不使用Type类的
IsPrimitive
?
XXX = field.FiledType.IsPrimitive
编辑:您必须将字符串视为一种特殊情况,因为IsPrimitive不会返回true.
编辑2:你遇到的问题是你试图嫁给两个与之不匹配的原始定义.因此,我只能看到两种选择:
>使两个定义匹配,显然您无法更改CLR类型系统,并且可能无法更改您正在使用的框架.>制造一些与两个定义“结合”的黑客.我没有看到硬编码与primitve类型的两个定义之一不匹配的特定异常的其他方法.