当前位置: 首页 > news >正文

函数式编程范式

文章目录

  • 函数式编程范式
    • 不可变性(Immutable)
    • 纯函数(Pure Functions)
    • 函数作为一等公民(First-Class Functions)
    • 高阶函数(Higher-Order Functions
    • 函数组合(Function Composition)或函数柯里化(Function Currying)
  • 函数式编程优势
  • 函数式编程缺陷
  • 函数式工具实践

函数式编程范式

不可变性(Immutable)

  • 数据是不可变的,即一旦创建就无法更改。这意味着对数据的所有操作都是返回新数据,而不是修改原始数据
// 不可变的数据操作
const arr = [1, 2, 3];
const newArr = arr.concat(4); // 返回一个新数组 [1, 2, 3, 4]

纯函数(Pure Functions)

  • 纯函数是指给定相同的输入,始终返回相同的输出,并且没有副作用(不修改外部状态,也不依赖于外部状态)
// 纯函数
function add(x, y) {return x + y;
}// 纯函数的特点:
// - 同样的输入 (2, 3) 总是返回相同的输出 (5)
// - 没有副作用,不修改外部状态

函数作为一等公民(First-Class Functions)

  • 函数是一等公民意味着函数可以像其他数据类型一样被传递、返回和存储。
  • 例如,可以将函数作为参数传递给另一个函数,或者将函数作为返回值返回
// 函数作为参数传递
function applyFunction(fn, value) {return fn(value);
}function square(x) {return x * x;
}console.log(applyFunction(square, 5)); // 输出 25// 函数作为返回值
function createAdder(x) {return function(y) {return x + y;};
}const addFive = createAdder(5);
console.log(addFive(10)); // 输出 15

高阶函数(Higher-Order Functions

  • 高阶函数是指接受一个或多个函数作为参数,或返回一个函数作为结果的函数。例如,map、filter 和 reduce 都是高阶函数
// 高阶函数
function map(array, fn) {let result = [];for (let i = 0; i < array.length; i++) {result.push(fn(array[i]));}return result;
}const numbers = [1, 2, 3];
const squared = map(numbers, (x) => x * x);
console.log(squared); // 输出 [1, 4, 9]

函数组合(Function Composition)或函数柯里化(Function Currying)

// 函数组合
function compose(f, g) {return function(x) {return f(g(x));};
}const addOne = (x) => x + 1;
const double = (x) => x * 2;const addOneAndDouble = compose(double, addOne);
console.log(addOneAndDouble(5)); // 输出 12

函数式编程优势

  • 原子化粒度:由函数组成一个个单元
  • 更易于测试:纯函数没有副作用,它们只依赖于输入参数,因此更容易编写测试用例和验证函数的正确性
  • 易于并行和并发编程:不可变性和纯函数使得并行计算变得更加安全,因为多个线程可以安全地并行执行不依赖于共享状态的纯函数
  • 函数复用:高阶函数和函数组合使得函数可以复用和组合,减少了代码重复,提高了代码的复用性
  • 可维护性:函数的重用和组合,使得代码更模块化,同时纯函数减少了代码变更带来的副作用
  • 利于 TypeScrpt:泛型能得到大量的应用

函数式编程缺陷

  • 可读性:高阶函数会降低可读性
  • 闭包:函数式编程会产生大量的闭包

函数式工具实践

  • Lodash/fp: 提供函数式编程风格的 Lodash 函数。
  • Ramda: 专注于函数式编程的 JavaScript 库。
http://www.lryc.cn/news/411158.html

相关文章:

  • 特征缩放的秘籍:sklearn中的数据标准化技术
  • hdfs文件系统
  • 基于STM32设计的个人健康检测仪(华为云IOT)(191)
  • 面试:CUDA Tiling 和 CPU tiling 技术详解
  • SQL语句中,`TRUNCATE` 和 `DELETE`的区别
  • 【Git】.gitignore全局配置与忽略匹配规则详解
  • 基于 YOLO V10 Fine-Tuning 训练自定义的目标检测模型
  • Java学习2
  • CSS、less、 Sass、
  • 北京大学:利用好不确定性,8B小模型也能超越GPT-4
  • ​​​​​​​哪些云服务商已通过了等保2.0合规性评估?​​​​​​​
  • PHP在线加密系统源码
  • OpenCV学习笔记 比较基于RANSAC、最小二乘算法的拟合
  • 前端JS特效第53集:带声音的烟花模拟绽放特效插件
  • 好展位,抢先订!2025浙江(玉环)机械展
  • Java面试八股之Spring如何解决循环依赖
  • 如何为 SQL Server 设置强密码以增强安全性?
  • C语言实现三子棋
  • 昇思25天学习打卡营第XX天|RNN实现情感分类
  • linux深度学习环境配置(cuda,pytorch)
  • SpringBoot教程(十九) | SpringBoot集成Slf4j日志门面
  • 科普文:深入理解ElasticSearch体系结构
  • 极限学习机(ELM)预测模型及其Python和MATLAB实现
  • 基于Python的哔哩哔哩国产动画排行数据分析系统
  • Java导出Excel给每一列设置不同样式示例
  • 2.1、matlab绘图汇总(图例、标题、坐标轴、线条格式、颜色和散点格式设置)
  • Datawhale AI夏令营 AI+逻辑推理 Task2总结
  • linux常使用的命令
  • Ubuntu系统U盘安装与虚拟机安装
  • FastDDS中的线程梳理