课程背景
- 前端的主要编程语言为JavaScript。
- JavaScript做为一种融合了多种编程范式的语言,灵活性非常高。
- 前端开发人员需要根据场景在不同编程范式间自如切换。
- 进一步需要创造领域特定语言抽象业务问题。
编译器:将高级语言转换成汇编语言,再将汇编语言转换成机器语言(二进制)
C/C++
C:“中级语言”过程式语言代表
- 可对位,字节,地址直接操作
- 代码和数据分离倡导结构化编程
- 功能齐全∶数据类型和控制逻辑多样化
- 可移植能力强
C++:面向对象语言代表
- C with Classes
- 继承
- 权限控制
- 函数
- 多态
Lisp:函数式语言代表
- 与机器无关
- 列表:代码即数据
- 闭包
JavaScript
- 基于原型和头等函数的多范式语言
- 过程式
- 面向对象
- 函数式
- 响应式
总结:编程语言分类
编程范式
结构化编程:采用区分块的结构
面向过程存在的问题
- 数据与算法关联弱
- 不利于修改和扩充
- 不利于代码重用
面向对象式编程
- 封装
- 继承
- 多态
- 注入依赖
面向对象-五大原则
- 单一职责原则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,一般都是由通用语言实现
语言运行
- lexer词法分析
- parser语法分析
- visit遍历
编译原理:这我熟:D
总结
正好最近要手写词法、文法分析器,最后做一个编译器,这节课程就当做是复习啦哈哈哈。