序列化对函数的调用

本文关键字:调用 函数 序列化 | 更新日期: 2023-09-27 18:11:19

我需要在应用程序中实现任务的概念。在我的项目中,任务是必须执行的操作,并由名称标识:每个任务也有输入参数(类型和值),并产生一个或多个输出。

必须实现Task类,我如何表达"具有某种结果的操作"的概念?我可以将操作的名称存储在字符串属性中,但是如何表示该操作返回的类型呢?类似地,当这些参数也可能是不同类型时,我如何实现操作的输入参数列表?

目标是序列化Task对象并将其发送到另一个节点。接收端分析接收到的Task对象,读取操作名称,并执行相应的函数。

例如,假设节点A和节点B"具有"以下方法…

节点A服务:

- double getAreaOfRectangle(double length, double width);
- double getAreaOfTriangle(double base, double height);
- double getAreaOfParallelogram(double base, double height).

节点B的服务:

- double getAreaOfCircle(double radius);
- double getAreaOfTrapezoid(double base1, double base2, double height).

如果节点C需要计算矩形的面积,它知道它必须联系节点a,并通过指定操作(double areaOfRectangle)和输入(double width和double height)向节点a发送消息。同样,如果节点C需要计算圆的面积,则必须向节点B发送消息,指定操作和半径的长度。为了发送输入,因为它们可以是不同的类型(甚至是新的用户定义的类型),我可以使用object的数组…

一些任务可能依赖于其他任务,例如,输入参数可能至少有另一个任务的一个输出,因此我还需要实现任务输出和另一个任务输入之间的链接。

我应该如何继续定义类?

序列化对函数的调用

你应该考虑在。net 4.0中使用表达式树。更多信息请参阅本文

c#中表达式树的序列化和反序列化