百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

[Java] 函数式编程相关概念 - 笔记2

ztj100 2024-12-07 18:47 20 浏览 0 评论

匿名函数 ( Anonymous function )

1. 匿名函数,是指没有被绑定到标识符的函数。根据字面意思,也可以理解为没有名字的函数。

2. 匿名函数通常:

1). 作为参数,被传递给高阶函数。

2). 作为高阶函数的返回值。

3. 在函数式编程语言,以及其他拥有头等函数的语言中,匿名函数比较普遍。

4. 在一些编程语言中,匿名函数被关键字 lambda 所标记。所以,匿名函数有也被称为Lambda 表达式 ( Lambda express )。例如,Python 就使用 lambda 进行标记

def h(x):
    return lambda y: x + y

5. 匿名函数是嵌套函数的一种,可以访问外层函数的变量,即其非局部变量。这也意味着,匿名函数需要实现闭包。

6. 匿名函数是一种编程风格。匿名函数从来都不会是解决问题的唯一方式。每一个匿名函数都可以重新定义为有名的函数,并调用该有名函数。

7. 匿名函数除了用于上面提到的高级函数,闭包之外,也常用于柯里化场景。

高阶函数( Higher-order function )

1. 一个函数被称为高阶函数,需要满足至少一个条件

1). 定义一个或多个函数作为自身的参数

2). 返回一个函数作为自身的返回值。

2. 上面 python 例子 h(x) 便是一个高阶函数。C 语言的标准函数 qsort 也是高阶函数。

map

1. map 是一个常见的高阶函数,将给定数据集合的每一个元素,传入给定函数中并进行调用,并返回被调用后的数据集合,元素次序不变。常被称为“apply-to-all”,即全部调用。

2. 下面是一个求平方的 map 应用,用 scheme 来实现。

先定义求平方算法

square x = x * x

然后调用 map

产生的结果为 [1, 4, 9, 16, 25]。

在 Java 8 中,引入了 stream.map(func) 来支持 map 功能。代码如下

        List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
        List<Integer> squreList = numbers.stream.map(i -> i*i).collect(Collectors.toList);
    
        System.out.println(numbers);    // output : [1, 2, 3, 4, 5]
        System.out.println(squreList);   // output : [1, 4, 9, 16, 25]

柯里化 ( Currying )

1. 柯里化是一种函数转换技术,将一个多参数的函数,转换为一些列只需要单个参数的函数,其中这一系列的函数单参数和之前的多参数一一对应。

function divide(x, y){ 
    return x / y 
}

function divior(d){
    return function(x){ 
        return divide( x, d);
    }
}

var half = divior(2)
var third = divior(3)

half(24)    // return 12
third(24)   // return 8

2. 在数学分析中,有一些分析技术只支持单参数函数,但是实用的函数通常定义多个参数。柯里化就是将多参数函数转化为一些系列的单参数函数。这个技术多用于理论分析,较少应用于工业生产。

头等函数 ( First-class function )

1. 一个编程语言支持头等函数,即意味着把函数作为一等公民,或者说是一等类型。拥有下面几个特性

1). 可以把函数作为参数传递给其他函数

2). 可以把函数作为其他函数的返回值

3). 可以把函数赋值给变量,或者存储到数据结构中。

2. 函数的标示符,就是一个普通的变量,类型为函数类型,没有其他特别状态。

3. 头等函数是函数式编程风格的前提条件,因为函数式编程把高阶函数作为常用的方式。

4. 一个函数可以成为一个变量的值,那么就要判断两个函数是否相等。主要有两种相等。

1). 内涵相等( Intensional equality )。通过对比函数体的源代码,来判断两个函数是否相等。

2). 引用相等( Reference equality )。所有的函数都有一个对应的标识符,通过判断两个函数的标识符是否相等来决定函数本身是否相等。所以,两个分别定义的方法,即使他们的源代码一抹一眼,也会被认为是不相等。大多数语言使用引用相等的方式来判断函数间是否相等。

5. Javascript 基本完整地支持头等函数。

Java 8 引入的闭包,仅仅能获取到不变的非局部变量。Java 里面还没有函数类型。

参考资料

相关推荐

离谱!写了5年Vue,还不会自动化测试?

前言大家好,我是倔强青铜三。是一名热情的软件工程师,我热衷于分享和传播IT技术,致力于通过我的知识和技能推动技术交流与创新,欢迎关注我,微信公众号:倔强青铜三。Playwright是一个功能强大的端到...

package.json 与 package-lock.json 的关系

模块化开发在前端越来越流行,使用node和npm可以很方便的下载管理项目所需的依赖模块。package.json用来描述项目及项目所依赖的模块信息。那package-lock.json和...

Github 标星35k 的 SpringBoot整合acvtiviti开源分享,看完献上膝盖

前言activiti是目前比较流行的工作流框架,但是activiti学起来还是费劲,还是有点难度的,如何整合在线编辑器,如何和业务表单绑定,如何和系统权限绑定,这些问题都是要考虑到的,不是说纯粹的把a...

Vue3 + TypeScript 前端研发模板仓库

我们把这个Vue3+TypeScript前端研发模板仓库的初始化脚本一次性补全到可直接运行的状态,包括:完整的目录结构所有配置文件研发规范文档示例功能模块(ExampleFeature)...

Vue 2迁移Vue 3:从响应式到性能优化

小伙伴们注意啦!Vue2已经在2023年底正式停止维护,再不升级就要面临安全漏洞没人管的风险啦!而且Vue3带来的性能提升可不是一点点——渲染速度快40%,内存占用少一半,更新速度直接翻倍!还在...

VUE学习笔记:声明式渲染详解,对比WEB与VUE

声明式渲染是指使用简洁的模板语法,声明式的方式将数据渲染进DOM系统。声明式是相对于编程式而言,声明式是面向对象的,告诉框架做什么,具体操作由框架完成。编程式是面向过程思想,需要手动编写代码完成具...

苏州web前端培训班, 苏州哪里有web前端工程师培训

前端+HTML5德学习内容:第一阶段:前端页面重构:PC端网站布局、HTML5+CSS3基础项目、WebAPP页面布局;第二阶段:高级程序设计:原生交互功能开发、面向对象开发与ES5/ES6、工具库...

跟我一起开发微信小程序——扩展组件的代码提示补全

用户自定义代码块步骤:1.HBuilderX中工具栏:工具-代码块设置-vue代码块2.通过“1”步骤打开设置文件...

JimuReport 积木报表 v1.9.3发布,免费可视化报表

项目介绍积木报表JimuReport,是一款免费的数据可视化报表,含报表、大屏和仪表盘,像搭建积木一样完全在线设计!功能涵盖:数据报表、打印设计、图表报表、门户设计、大屏设计等!...

软开企服开源的无忧企业文档(V2.1.3)产品说明书

目录1....

一款面向 AI 的下一代富文本编辑器,已开源

简介AiEditor是一个面向AI的下一代富文本编辑器。开箱即用、支持所有前端框架、支持Markdown书写模式什么是AiEditor?AiEditor是一个面向AI的下一代富文本编辑...

玩转Markdown(2)——抽象语法树的提取与操纵

上一篇玩转Markdown——数据的分离存储与组件的原生渲染发布,转眼已经鸽了大半年了。最近在操纵mdast生成md文件的时候,心血来潮,把玩转Markdown(2)给补上了。...

DeepseekR1+ollama+dify1.0.0搭建企业/个人知识库(入门避坑版)

找了网上的视频和相关文档看了之后,可能由于版本不对或文档格式不对,很容易走弯路,看完这一章,可以让你少踩三天的坑。步骤和注意事项我一一列出来:1,前提条件是在你的电脑上已配置好ollama,dify1...

升级JDK17的理由,核心是降低GC时间

升级前后对比升级方法...

一个vsCode格式化插件_vscode格式化插件缩进量

ESlint...

取消回复欢迎 发表评论: