编程范式 | 青训营笔记

86 阅读2分钟

课程背景

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

编译器:将高级语言转换成汇编语言,再将汇编语言转换成机器语言(二进制)

C/C++

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

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

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

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

Lisp:函数式语言代表

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

JavaScript

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

总结:编程语言分类

image.png

编程范式

结构化编程:采用区分块的结构

面向过程存在的问题

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

面向对象式编程

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

面向对象-五大原则

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

函数式编程

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

响应式编程

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

响应式编程-操作符

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

领域特定语言

如HTML,SQL,一般都是由通用语言实现

语言运行

  1. lexer词法分析
  2. parser语法分析
  3. visit遍历

编译原理:这我熟:D

总结

image.png

正好最近要手写词法、文法分析器,最后做一个编译器,这节课程就当做是复习啦哈哈哈。