编程范式 | 青训营笔记

113 阅读2分钟

[编程范式 | 青训营笔记]

第四节课编程范式,讲师何一鸣,时长43min7s。

一、课程介绍

课程背景

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

课程收益

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

二、编程语言

语言的历程

  1. 高级语言
  • C = A+ B
  1. 汇编语言
  • LOAD AADD B
  • STORE C
  1. 机器语言
  • 1223423453245
  • 0345234523452
  • 3467896789456768
  • 12234345435645

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

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

高级语言

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

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

Lisp:函数式语言代表

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

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

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

三、编程范式

过程式

  • 自顶向下
  • 结构化编程
  • 问题

面向对象

  • 封装
  • 继承
  • 多态
  • 原则
  • 问题

函数式编程

  • 一等函数
  • 纯函数
  • curry/compose/functor/monard/applicative

响应式编程

  • observable
  • 操作符
  • monard

四、领域特定语言

什么是领域特定语言

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

  • HTML
  • SQL

语言运行

lexer

SQL Token 分类

  1. 注释
  2. 关键字
  3. 操作符
  4. 空格字符串
  5. 变量

Parser_语法规则

  1. 上下文无关语法规则
- <selectStatement> ::= SELECT <selectList> FROM <tableName>
- <selectList> ::= <selectField> [ ,<selectList> ]
- <tableName> ::= <tableName>[,<tableList> ]
  1. 推导式:表示非终结符到(非终结符或终结符)的关系。
  2. 终结符:构成句子的实际内容。可以简单理解为词法分析中的token。
  3. 非终结符:符号或变量的有限集合。它们表示在句子中不同类型的短语或子句。

还有tools、vistor。

掌握 JavaScript 在不同的编程范式特别是函数式编程范式下的使用。同时进一步掌握创建领域特定语言的相关工具和模式。