编程范式 | 青训营笔记

68 阅读2分钟

课程背景:

  1. 前端的主要编程语言为Javascript。
  2. Javascript做为一种融合了多种编程范式的语言,灵活性非常高。
  3. 前端开发人员需要根据场景在不同编程范式间字汝晞切换。
  4. 进一步需要制造领域特定语言抽象业务问题。

课程收益:

  1. 了解不同编程范式的起源和使用场景。
  2. 掌握Javascript在不同的编程范式特别是函数式编程范式的使用。
  3. 掌握创建领域特定语言的相关工具和模式。

高级语言:

C/C++
C:“中级语言”过程式语言代表

  • 可对位,字节地址直接操作;
  • 代码和数据分离倡导结构化编程
  • 功能齐全:数据类型和控制逻辑多样化
  • 可移植能力强

C++:面向对象语言代表

  • C with Classes
  • 继承
  • 权限控制
  • 虚函数
  • 多态

Lisp:函数式语言代表

  • 与机器无关
  • 列表:代码即数据
  • 闭包

Javascript

  • 基于原型和头等函数的多范式语言
  • 过程式
  • 面向对象
  • 函数式
  • 响应式*

image.png

编程范式

分类:

  1. 命令式:面向过程;面向对象
  2. 声明式:函数式;响应式

过程式编程:自顶向下

image.png

结构化编程:
顺序结构;选择结构;循环结构

面向过程问题

  • 数据与算法全联弱
  • 不利于修改和扩充
  • 不利于代码重用

面向对象编程

  • 封装
  • 继承
  • 多态
  • 依赖注入*

面向对象编程五大原则:

  • 单一职责原则SSR
  • 开放封闭原则OCP
  • 里式替换原则LSP
  • 依赖倒置原则DIP
  • 接口分离原则ISP

面向对象问题:
面向对象编程语言的问题在于,它总是附带着所有它需要的隐含环境。你想要一个香蕉,但得到的却是一个大猩猩拿着香蕉,而且还有整个丛林。
————Joe Armstrong (Erlang创始人)

函数式编程

  • 函数是“第一等公民”
  • 纯函数/无副作用
  • 高阶函数/闭包

函数式编程_Pure Function

  • 优势
  • 可缓存
  • 可移植
  • 可测试
  • 可推理
  • 可并行

函数式编程_Currying

函数式编程_Composition

  • 可以当作容器的类型,类型支持对容器内元素进行操作
  • 常见的functor:Array(lterable).map,Promise.then

函数式编程_Monad

  • 可以去除嵌套容器的容器类型
  • 常见monad:Array.flatMap Promise.then

函数式编程_Applicative

  • 直接对两个容器直接操作

响应式编程

  • 异步/离散的函数式编程
  • 数据流
  • 操作符
  • 过滤
  • 合并
  • 转化
  • 高阶

响应式编程

  • 观察者模式
  • 迭代器模式
  • Promise/EventTarget超集*

响应式编程_操作符

  • 响应式编程的“compose”
  • 合并
  • 过滤
  • 转化
  • 异常处理

响应式编程_Monad

  • 去除嵌套的Observable
  • 多播

image.png

image.png