编程范式4| 青训营笔记

54 阅读2分钟

一、编程语言

  • 机器语言
  • 汇编语言
  • 中级语言——面向过程代表(C)
  • 高级语言
面向对象代表(C++)
函数式代表(Lisp)
多范式代表(JavaScript

二、编程范式

程序语言特性

  • 是否允许副作用
  • 操作的执行顺序
  • 代码组织
  • 状态管理
  • 语法和词法

常见的编程范式

  • 命令式

面向过程

面向对象

  • 声明式

函数式

响应式

过程式编程

  • 自顶向下
          模块——变量——数据结构
程序——
          函数——函数——语句
  • 结构化编程

面向过程问题

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

面向对象编程

  • 封装——关联数据与算法
  • 继承——无需重写的情况下进行功能扩充
  • 多态——不同的结构可以进行接口共享,进而达到函数复用
  • 依赖注入——去除代码耦合

面向对象编程_五大原则

  • 单一职责原则SRP(Single Responsibility Principle)
  • 开放封闭原则OCP(Open -Close Principle)
  • 里式替换原则LSP(the Liskov Substitution Principle LSP)
  • 依赖倒置原则DIP(the Dependency Inversion Principle DIP)
  • 接口分离原则ISP(the Interface Segregation Principle lSP)

面向对象_问题

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

函数式编程

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

函数式编程优势

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

响应式编程

异步/离散的函数式编程

  • 数据流
  • 操作符

过滤 合并 转化 高阶

三、领域特定语言

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

lexer

SQL Token分类

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

Parser_语法规则

  • 推导式:表示非终结符到(非终结符或终结符)的关系。
  • 终结符:构成句子的实际内容。可以简单理解为词法分析中的token。
  • 非终结符∶符号或变量的有限集合。它们表示在句子中不同类型的短语或子句。

收获:

通过对本次课程的学习,使我了解了不同编程范式的起源和适用场景。初步掌握JavaScript在不同的编程范式,特别是函数式编程范式的使用。初步掌握创建领域特定语言的相关工具和模式。