C#函数式编程之标准高阶函数
2015-01-27 09:20
197 查看
何为高阶函数
大家可能对这个名词并不熟悉,但是这个名词所表达的事物却是我们经常使用到的。只要我们的函数的参数能够接收函数,或者函数能够返回函数,当然动态生成的也包括在内。那么我们就将这类函数叫做高阶函数。但是今天我们的标题并不是高阶函数,而是标准高阶函数,既然加上了这个标准,就意味着在函数式编程中有一套标准的函数,便于我们每次调用。而今天我们将会介绍三个标准函数,分别为Map、Filter、Fold。Map
这个函数的作用就是将列表中的每项从A类型转换到B类型,并形成一个新的类型。下面我们可以看看在FCSLib中是如何实现的:相信很多人应该都能够看懂这段代码,仅仅只是循环list数据。然后调用convert函数转换,最后通过yield将其组成一个列表返回。下面我们通过一个简单的例子来演示下如何使用这个标准高阶函数:
我们通过声明了一个数组data,然后利用map函数将其中的ID提取出来,单独形成一个列表。
Filter
通过名字应该能够猜出他大概的含义了,就是用来过滤数据的。相信一些人能够根据上面写出这个标准高阶函数的具体实现,当然这里不管读者有没有写出,我们都来看看FCSLib中是如何实现的:这里我们只是少了一个泛型参数,对应的第一参数的是能够接收T类型返回bool类型的函数(Predicate也是.NET自带的,可能我们用惯了Func和Action,并且利用Func<T,bool>也可以实现一样的效果。),而语句主要是在循环后调用了predicate去判断是否满足条件,如果满足条件则返回。
Fold
这个标准高阶函数可能会比较难,因为它分为了左折叠和右折叠两种。接收的参数有三个,分别是起始值,累加函数,列表。大致的执行过程就是在第一次调用我们的累加函数时将起始值作为一个参数,而列表中的第一个值作为第二个参数去调用我们的累加函数,累加函数计算出结果,而这个结果将作为下一次调用累加函数时的第一参数,而第二个参数则是列表中的下一项,以此类推。所以通过这个高阶函数我们可以直接计算出列表中每项数据累加后的结果,而在FCSLib中的具体实现则如下所示:通过查看源代码我们也可以得出之前的执行流程,在第一次的时候v的值为startValue,而之后就会将accmulator函数的返回值保存进v,这样下一次执行accmulator时就作为第一个参数传入。下面我们通过一个简单的例子来看看如何使用:
左折叠完成之后对应的还有一个右折叠,当然根据名字也可以猜出。就是从list的末尾开始进行循环,所以我们可以这样来实现FoldR:
这里还要指出的就是左折叠和右折叠是最常用的算法之一,他完全可以实现像我们之前介绍过的Map和Filter,而只要按照下面这种方式写即可:
这里我们就是利用Fold函数的一个特性来实现的,因为累加函数每次都会将上一次计算得出的结果传递给下一个累加函数(new List<R>()我们直接将其作为起始值传入),最后我们都会通过return x将这个列表返回,这样下一次再调用这个累加函数之后x依然是同一个列表。对应的还有Filter的实现:
而具体的调用方式则和Map,Filter是一致的,并没有什么特别大的区别。
关于Linq中的Map、Filter和Fold
其实函数式编程已经在不知不觉中慢慢的进入到我们的生活中,其实我们经常在Linq中使用的select、where和aggregate就是对应着函数式编程中的map、filter和fold。相关文章推荐
- C#函数式编程之标准高阶函数
- C#中的函数式编程:递归与纯函数(二) 学习ASP.NET Core Razor 编程系列四——Asp.Net Core Razor列表模板页面
- C#2005 .NET3.0高级编程学习笔记————类的函数成员(构造函数,只读字段)
- 使用C#创建webservice及三种调用方式 (ASP.NETweb编程常用到的27个函数集)
- C#编程--函数
- 转自:Python函数式编程指南(二):函数
- 【linux系统编程】C标准I/O函数和系统无缓冲函数(Unbuffered I/O函数)关系
- C#的委托与JavaScript的函数式编程
- <PY><core python programming笔记>C11 函数和函数式编程
- C#编程--函数
- C库函数标准编程之fscanf()函数解读及其实验
- C++标准编程:虚函数与内联
- 学习C#高级编程--在重写基类的方法中,如何调用基类的函数
- F#程序设计-函数式编程之函数组合(Function Composition)
- F#程序设计-函数式编程之用函数风格来编程(2)
- Python学习笔记《Python核心编程》第11章 函数和函数式编程
- C#2005 .NET3.0高级编程学习笔记————类和结构,类的数据成员,类的函数成员(方法、属性)
- F#程序设计-函数式编程之用函数风格来编程(1)
- 从C#到Python —— 3 函数及函数编程
- UC编程:通过fwrite()和write()比较标准库函数和系统调用的速度