编程范式 | 青训营

137 阅读3分钟

编程语言

机器语言

汇编语言

高级语言

C:"中级语言" 过程式语言代表

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

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

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

Lisp:函数式语言代表

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

JavaScript:基于原型和头等函数的多范式语言

  • 过程式
  • 面向对象
  • 函数式
  • 响应式

小结

编程范式

什么是编程范式

常见编程范式

过程式编程

自顶向下

结构化编程

JS中的面向过程

面向过程问题

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

面向对象编程

封装

  • 关联数据与算法

继承

  • 无需重写的情况下进行功能补充

多态

  • 不同的结构可以进行接口共享,进而达到函数复用

依赖注入

  • 去除代码耦合

五大原则

单一职责原则SRP(Single Responsibility Principle)

开放封闭原则OCP(Open-Close Principle)

里式替换原则LSP(the Liskov Substitution Principle)

依赖倒置原则DIP(the Dependency Inversion Principle)

接口分离原则ISP(the Interface Segregation Principle)

面向对象问题

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

函数式编程

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

First Class Function

Pure Function

优势

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

Currying

Composition

Functor

可以当做容器的类型,类型支持对容器内元素进行操作

常见的functor:Array(Iterable).map,Promise.then

Monad

可以去除嵌套容器的容器类型

常见monad:Array.flatMap Promise.then

Applicative

直接对两个容器直接操作

响应式编程

异步/离散的函数式编程

  • 数据流

  • 操作符

    • 过滤
    • 合并
    • 转化
    • 高阶

Observable

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

操作符

响应式编程的“compose”

  • 合并
  • 过滤
  • 转化
  • 异常处理
  • 多播

Monad

去除嵌套的Observable

小结

领域特定语言

  • Domain-specific language (DSL):应用于特定领域的语言

    • HTML
    • SQL
  • General-purpose language

    • C/C++
    • Javascript
    • ...

语言运行

lexer

SQL Token分类

  • 注释
  • 关键字
  • 操作符
  • 字符串
  • 变量

Parser语法规则

上下文无关语法规则

推导式:表示非终结符到(非终结符或终结符)的关系。

终结符:构成句子的实际内容。可以简单理解为词法分析中的token。

非终结符:符号或变量的有限集合。它们表示在句子中不同类型的短语或子句。

LL

从左到右检查,从左到右构建语法树

LR

从左到右检查,从右到左构建语法树

LL(K) > LR(1) > LL(1)

tools

visitor

小结