根据数据库中的数据动态调用C#方法
我的老板让我调查计算引擎.实际上,用户将拥有可以进行计算的数据表.他们还可以根据我们强制执行的某些限制来构建自己的计算(然后将构建的计算存储在数据库中)
是否可以在C#中调用特定方法,具体取决于数据库中存储的内容?因此,如果数据库说,计算应执行标准偏差.当我们从数据库中获取该信息时,是否可以调用我们将在C#中使用的标准偏差方法?
我希望这很清楚.
解决方法:
考虑到将对您的数据执行的小/已知操作量,我将根据从数据库检索的数据选择手动编码这些操作.对于可扩展性/可维护性,最好为此创建一个合适的设计,而不是使用简单的switch语句.我猜测Strategy pattern会满足你的需求.
正如其他人所说,您可以使用reflection来调用数据库中指定的方法.此方法的问题是数据库中的数据与方法签名密切相关.这比第一种方法的可维护性更低,但确实可以通过最少的代码调整实现极佳的可扩展性.另一个缺点是使用MethodInfo.Invoke()相当慢.
如果您选择反射,但发现Invoke()方法太慢,我可以推荐this article by Jon Skeet,它解释了如何将MethodInfo转换为委托实例.这提供了一个主要的速度提升.我最近为此写了a generic implementation using expression trees.
总而言之,似乎选项1仍然是最适合您的目的.