我得到以下代码生成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类型的两个定义之一不匹配的特定异常的其他方法.