编程范式|青训营笔记

96 阅读3分钟

目录

1.课程介绍 2.编程语言 3.编程范式 4.领域特定语言

01.课程介绍

背景: 前端主要的编程语言是JavaScript,是融合了多种编程范式的语言,灵活性很高;要求根据场景在不同编程范式间自如切换,进一步需要在创造领域特定语言抽象业务问题。

02.编程语言

  • 机器语言
  • 汇编语言
  • 中级语言---C:"中级语言"过程式语言代表

可对位,字节,地址直接操作

代码和数据分离倡导结构化编程

功能齐全:数据类型和控制逻辑多样化

可移植能力强

  • 高级语言
  • C++:面向对象语言代表

C with Classes

继承

权限控制

虚函数

多态

  • Lisp:函数式语言代表

与机器无关

列表:代码即数据

闭包

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

过程式

面型对象

函数式

响应式*

03.编程范式

image.png
过程式编程
  • 自顶向下

  • 结构化编程

面向过程问题
  • 数据与算法关联弱
  • 不利于修改和扩充
  • 不利于代码重用
面向对象编程_封装
  • 关联数据与算法
面向对象编程_继承

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

面向对象编程_多态

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

面向对象编程_依赖注入

去除代码耦合

面向对象编程_五大原则
  • 单一职责原则SRP
  • 开放封闭原则OCP
  • 里式替换原则LSP
  • 依赖倒置原则DIP
  • 接口分离原则ISP

函数式编程

  • 函数是“第一等公民”
  • 纯函数/无副作用
  • 高阶函数/闭包
函数式编程_First Class Function

聚合转发

函数式编程_Pure Function

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

函数式编程_Currying
函数式编程_Composition
函数式编程_Functor

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

常见的functor:Array(lterable).map,promise.then

函数式编程_Monad

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

常见的monad:Array.flatMap Promise.then

函数式编程_Applicative

直接对两个容器直接操作

响应式编程

异步/离散的函数式编程

  • 数据流
  • 操作符
    • 过滤
    • 合并
    • 转化
    • 高阶
响应式编程_Observable
  • 观察者模式
  • 迭代器模式
  • promise/EventTarget超集*
响应式编程_操作符

响应式编程的“compose”

  • 合并
  • 转化
  • 过滤
  • 异常处理
  • 多播
响应式编程_Monad

去除嵌套的Observable

04.领域特定语言

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

  • HTML
  • SQL
语言运行

lexer

SQL Token分类

  • 注释
  • 关键字
  • 操作符
  • 空格
  • 字符串
  • 变量
Pater_语法规则
  • 推导式:表示非终结符到(非终结符到终结符)的关系。
  • 终结符:构成句子的实际内容。可简单理解为词法分析中的token。
  • 非终结符:符号或变量的有限集合。它们表示在句子中不同类型的短语或子句。
Parser_LL

L1:从左到右检查,从左到右构建语法数。

select name from user

总结

通过这节课的学习,我了解到了JavaScript是一种融合了多种编程范式的语言,掌握JavaScript在不同编程范式下的使用是十分关键的。这节课我了解到了编程语言以及编程语言的使用过程,编程范式以及构建领域特定语言,学到了词法和语法的解析分析,收获颇多。