当属性类型未知时,为通过反射获取的属性访问器创建委托
在 .NET 2.0(使用 C# 3.0)中,当我在编译时不知道其类型时,如何为通过反射获取的属性访问器创建委托?
例如,如果我有 int
类型的属性,我可以这样做:
Func<int> getter = (Func<int>)Delegate.CreateDelegate(
typeof(Func<int>),
this, property.GetGetMethod(true));
Action<int> setter = (Action<int>)Delegate.CreateDelegate(
typeof(Action<int>),
this, property.GetSetMethod(true));
但是如果我在编译时不知道该属性是什么类型,我不知道该怎么做。
In .NET 2.0 (with C# 3.0), how can I create a delegate for a property accessor obtained via reflection when I don't know its type at compile time?
E.g. if I have property of type int
, I can do this:
Func<int> getter = (Func<int>)Delegate.CreateDelegate(
typeof(Func<int>),
this, property.GetGetMethod(true));
Action<int> setter = (Action<int>)Delegate.CreateDelegate(
typeof(Action<int>),
this, property.GetSetMethod(true));
but if I do not know what type the property is at compile time, I don't know how to do it.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您需要的是:
但是,如果您这样做是为了提高性能,那么您仍然会遇到不足,因为您需要使用
DynamicInvoke()
,这慢。您可能想看看元编程来编写一个接受/返回对象
的包装器。或者查看 HyperDescriptor,它可以为您完成此操作。What you need is:
however, if you are doing this for performance, you are still going to come up short, since you would need to use
DynamicInvoke()
, which is slooow. You might want to look at meta-programming to write a wrapper that takes/returnsobject
. Or look at HyperDescriptor which does this for you.