.NET并发编程中,函数闭包如何实现长尾调用优化?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1491个文字,预计阅读时间需要6分钟。
函数式编程是一种编程范式,其中一个函数输出作为另一个函数的输入。有时,一个复杂的问题可以被分解成多个步骤,每个步骤都是一个函数。这些函数组合起来,共同解决一个复杂问题。在C语言中,我们可以通过编写多个函数来实现这一点。
函数式编程
一个函数输出当做另一个函数输入。有时候一个复杂问题,我们拆分成很多个步骤函数,这些函数组合起来调用解决一个复杂问题。
在C#中不支持函数组合,但可以直接像这样调用B(A(n)),这也是函数组合,但这不利于阅读,人们习惯从左往右阅读,而不是相反的方向。通过创建扩展方法可以任何组合两个函数,像下面这样
Func<A,C> Compose<A,B,C>(this Func<A.B> f ,Func<B,C> g)=>(n)=>g(f(n))
上述代码为泛型委托Func<a,b>创建了一个扩展Compose的扩展方法,以泛型委托Func<b,c>为输入参数,返回组合后的函数Func<a,c>。创建一个高阶函数Compose把不利于阅读的隐藏起来。
在F#中就非常方便的使用函数组合。举个例子,将一个列表中数字增加4再乘以3,构建这两个步骤的函数(当然利用C#linq或F#map可以直接(x+4)*3,这里主要演示两个功能函数如何组合起来)。
本文共计1491个文字,预计阅读时间需要6分钟。
函数式编程是一种编程范式,其中一个函数输出作为另一个函数的输入。有时,一个复杂的问题可以被分解成多个步骤,每个步骤都是一个函数。这些函数组合起来,共同解决一个复杂问题。在C语言中,我们可以通过编写多个函数来实现这一点。
函数式编程
一个函数输出当做另一个函数输入。有时候一个复杂问题,我们拆分成很多个步骤函数,这些函数组合起来调用解决一个复杂问题。
在C#中不支持函数组合,但可以直接像这样调用B(A(n)),这也是函数组合,但这不利于阅读,人们习惯从左往右阅读,而不是相反的方向。通过创建扩展方法可以任何组合两个函数,像下面这样
Func<A,C> Compose<A,B,C>(this Func<A.B> f ,Func<B,C> g)=>(n)=>g(f(n))
上述代码为泛型委托Func<a,b>创建了一个扩展Compose的扩展方法,以泛型委托Func<b,c>为输入参数,返回组合后的函数Func<a,c>。创建一个高阶函数Compose把不利于阅读的隐藏起来。
在F#中就非常方便的使用函数组合。举个例子,将一个列表中数字增加4再乘以3,构建这两个步骤的函数(当然利用C#linq或F#map可以直接(x+4)*3,这里主要演示两个功能函数如何组合起来)。

