我的老板让我调查计算引擎.实际上,用户将拥有可以进行计算的数据表.他们还可以根据我们强制执行的某些限制来构建自己的计算(然后将构建的计算存储在数据库中)是否可以在C#中调用特定方法,具体取决于数据库中存储的内...
我的老板让我调查计算引擎.实际上,用户将拥有可以进行计算的数据表.他们还可以根据我们强制执行的某些限制来构建自己的计算(然后将构建的计算存储在数据库中)
是否可以在C#中调用特定方法,具体取决于数据库中存储的内容?因此,如果数据库说,计算应执行标准偏差.当我们从数据库中获取该信息时,是否可以调用我们将在C#中使用的标准偏差方法?
我希望这很清楚.
解决方法:
考虑到将对您的数据执行的小/已知操作量,我将根据从数据库检索的数据选择手动编码这些操作.对于可扩展性/可维护性,最好为此创建一个合适的设计,而不是使用简单的switch语句.我猜测Strategy pattern会满足你的需求.
正如其他人所说,您可以使用reflection来调用数据库中指定的方法.此方法的问题是数据库中的数据与方法签名密切相关.这比第一种方法的可维护性更低,但确实可以通过最少的代码调整实现极佳的可扩展性.另一个缺点是使用MethodInfo.Invoke()相当慢.
如果您选择反射,但发现Invoke()方法太慢,我可以推荐this article by Jon Skeet,它解释了如何将MethodInfo转换为委托实例.这提供了一个主要的速度提升.我最近为此写了a generic implementation using expression trees.
总而言之,似乎选项1仍然是最适合您的目的.
本文标题为:根据数据库中的数据动态调用C#方法
基础教程推荐
- Unity3d实现Flappy Bird游戏 2023-01-06
- LINQ基础之Intersect、Except和Distinct子句 2023-05-31
- C#实现控制电脑注销,关机和重启 2023-07-04
- C# MemoryStream类案例详解 2023-04-27
- c#中LINQ的基本用法(二) 2023-05-31
- C# websocket及时通信协议的实现方法示例 2022-11-24
- 浅析C# 状态机Stateless 2023-03-04
- C#中Entity Framework常见报错汇总 2022-11-24
- Unity Shader实现裁切效果 2023-02-16
- Unity实现10天签到系统 2023-04-14