前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >函数式编程中的基本概念

函数式编程中的基本概念

作者头像
丹枫无迹
发布2020-06-03 08:55:19
4130
发布2020-06-03 08:55:19
举报
文章被收录于专栏:学无止境学无止境

函数签名

假设有一个函数 f,输入一个 int 值,返回一个 string 值,在 C# 中,该函数可以表示为:

代码语言:javascript
复制
Func<int, string>

我们可以使用箭头(→)符号来表示:

代码语言:javascript
复制
f : int → string

箭头符号是函数式编程社区的标准函数符号,与语言无关。

当没有输入或没有输出(void)时,用 () 表示。如果有多个输入或输出,则用元组表示。

例如:

代码语言:javascript
复制
Func<string>
Func<int, int, int>

分别表示为:

代码语言:javascript
复制
() → string
(int, int) → int

对于高阶函数,可以嵌套表示。

例如 IEnumerable.Where 的签名:

代码语言:javascript
复制
Func<IEnumerable<T>, Func<T, bool>, IEnumerable<T>>

// IEnumerable<T> Where<T>(this IEnumerable<T> source, Func<T, bool> predicate);

可以表示为:

代码语言:javascript
复制
(IEnumerable<T>, (T → bool)) → IEnumerable<T>

函数的纯洁性

纯函数 是指没有任何副作用的函数,除了根据输入值计算输出值之外,什么也不做。而不纯函数则可能导致副作用。

副作用包括:

  • 使全局状态改变:这里的“全局”是指函数作用域之外。
  • 改变其输入参数
  • 抛出异常
  • 执行任何 I/O 操作

纯函数拥有许多的好处:

  • 并行化:由于输出值仅依赖于输入值,所以可以并行执行任务。
  • 惰性求值
  • 记忆化:缓存函数结果,以便只计算一次。

诚实的函数

诚实的函数始终履行自己的签名。

例如如下函数,就是一个诚实的函数:

代码语言:javascript
复制
public int Square(int n) => n * n;

而如下函数则是不诚实的:

代码语言:javascript
复制
public int Square(int n)
{
    if (n < 0) throw new ArgumentException();

    return n * n;
}

因为它可能返回一个 int 值,还可能抛出异常。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-06-02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 函数签名
  • 函数的纯洁性
  • 诚实的函数
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档