您能否在 C# 中将一个委托的结果链接为另一个委托的输入?
我正在寻找一种方法来链接多个代表,以便一个代表的结果成为下一个代表的输入。我试图在方程求解程序中使用它,其中部分是通过不同的方法完成的。这个想法是,当您构建方程时,程序会添加代表并按特定顺序链接它们,以便可以正确求解。如果有更好的方法来解决这个问题,请分享。
I am looking for a way to chain several delegates so the result from one becomes the input of the next. I am trying to use this in equation solving program where portions are done by different methods. The idea is that when you are building the equation the program adds the delegates and chains them in a particular order, so it can be solved properly. If there is a better way to approach the problem please share.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
这可能会有所帮助:
这会执行函数组合,运行
innerFunc
并传递当提供初始参数时,结果返回到outerFunc
:This might help:
This performs function composition, running
innerFunc
and passing the result toouterFunc
when the initial argument is supplied:是的,这是可能的 - 您需要确保委托的返回类型是被调用委托的参数类型。
很多 LINQ 都是以这种方式构建的,尽管您可能想看看表达式。
Yes this is possible - you need to ensure that the return type of the delegate is one that is the parameter type of the delegate being invoked.
A lot of LINQ is built this ways, though you may want to take a look at expressions.
您描述的 API 类型称为 Fluent API。请参阅前面的文章以获得很好的教程。
关于委托链接,请查看 .NET 3.5 中的 LINQ 扩展方法,特别是 lambda 函数(委托)如何传递给函数导致 IEnumerable 结果,然后可以将其与另一个扩展方法 + lambda 链接。
在您的特定情况下,您可能需要创建一个名为 Functor 的类来接受委托并返回另一个也可以由委托操作的 Functor。
此致,
The type of API you are describing is called a Fluent API. Take a look at the preceeding article for a good tutorial.
With regard to delegate chaining, take a look at the LINQ extension methods in .NET 3.5, in particular how lambda functions (delegates) passed to a function result in an IEnumerable result which can then be chained with another extension method + lambda.
In your specific case you might need to create a class called a Functor to accept a delegate and return another Functor which too can be operated on by delegates.
Best regards,
使用 GetIncationList 你可以实现这一点。
using GetInvocationlist you can achieve this.
我自己一直在研究一个类似的问题,其中涉及调用一系列委托并将一个委托的输出传递给下一个委托(依此类推......),所以我想您可能有兴趣查看我开发的代码作为概念验证:
该序列必须包含相同类型的委托,因此不如已接受的答案那么强大,但通过一些调整,可以将这两个代码组合起来以提供强大的解决方案。
I have been working on a similar problem myself which involved invoking a sequence of delegates and passing the output of one delegate to the next (and so on...) so thought you might be interested to see the code I developed as a proof-of-concept:
The sequence has to contain delegates of the same type so is not as powerful as the already accepted answer but with a few tweaks, both bits of code could be combined to provide a powerful solution.