我的老板让我调查计算引擎.实际上,用户将拥有可以进行计算的数据表.他们还可以根据我们强制执行的某些限制来构建自己的计算(然后将构建的计算存储在数据库中)是否可以在C#中调用特定方法,具体取决于数据库中存储的内...

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


基础教程推荐
- C#集合之自定义集合类 2023-06-04
- C# 如何生成 DataMatrix 格式的二维码 2023-05-06
- unity shader实现较完整光照效果 2023-02-03
- C# OpenCV实现形状匹配的方法详解 2023-07-04
- Unity使用LineRender断笔写字 2023-01-27
- C#随机数生成字母金字塔 2023-01-06
- NancyFx框架检测任务管理器详解 2022-11-22
- C#控制台应用(.NET Core)添加System.Windows.Forms失败(未解决) 2023-09-27
- Unity实现通用的信息提示框 2023-03-03
- WPF实现能自由改变形状的四边形和六边形 2023-07-18