• 【SICP】引入与教学大纲


    主题一:黑盒

    计算机中的组件是抽象自由的,在构建大系统时,理想与现实没有太大的不同

    案例:通过求不动点求平方根

    不动点:f 的不动点 Y 满足 f(Y)=Y

    求不动点的具体思路:

    1. 猜测 Y 是 A
    2. 迭代函数 f,直到结果不会变化

    x \sqrt x x ,就是求 f ( y ) = x / y f(y)=x/y f(y)=x/y的不动点

    我们希望将求不动点的过程封装成一个黑盒,然后通过这个盒子来求平方根

    目标:创建求不动点的黑盒

    这个盒子接收的不仅是数,还要能接收函数和过程

    在这个问题里,我们要传给它 f 和 x,然后输出的是一个计算平方根的函数

    所以,这是一个生成函数的函数,一个生成通法的通法

    函数 Function 和过程 Procedure:Pascal-like 语言里,和 function 的区别是有没有 return value,C-like 里面区别不大

    Primitive Objects 基本对象,包含基本过程和基础数据

    关于 Lisp 的语法

    Primitive Procedures

    Primitive Data

    Means of Combination:将基础数据和基本过程结合来构建更复杂的东西

    Procedure Composition

    Construction of Compound Data:将基础数据结合成复合数据

    Means of Abstraction

    Procedure Definition

    Simple Data Abstraction:数据抽象技术,用于处理复合数据

    Capturing Common Patterns

    High-Order Procedures 高阶过程,输入,输出和它本身都是过程

    Data as Procedure 数据和过程的分界线变得模糊了

    主题二:约定接口。按照约定来实现对应的接口,然后组合

    案例:计算(* x (+ a1 a2)),对任意不同类型的 a1 a2

    用中缀表达式是这样的(a1+a2)*a3

    我们希望的是,不管 a1,a2 是向量,或者电信号,声波的什么类型,我们的过程仍要有效

    若 a1,a2 是多项式,最后的结果要是格式化好的多项式

    目标:设计新的语言

    希望任意来一种新类型的对象,都可以直接使用系统,而不会把系统弄乱

    Conventional Interfaces

    Generic operations 通用操作

    Large-Scale Structure and Modularity 大型架构

    对现实世界的大型系统建模来构建大型程序

    Object-Oriented Programming 面向对象编程

    通过相互传递消息联系

    Operations on Aggregates 聚集的操作

    流 streams

    主题三:元语言抽象(Metalinguistic Abstraction)

    控制系统复杂度的方法:构建一门新的语言,强调系统的某个方面而隐藏某些细节

    Y operator Y 运算符:在过程式语言中表达无限
    (YF)=(F(YF))

    了解 Lisp 解释的过程(process of interpretation):EVAL 求值 APPLY 应用的相互轮转 apply-eval loop

    实现在有 Lisp 解释器的芯片(chip)

  • 相关阅读:
    技术管理三级跳
    性能测试常见分类
    【HarmonyOS】HarmonyOS Test测试用例中一些断言API的使用
    记录-2023/11/18
    vue监听表单输入的身份证号自动填充性别和生日
    Android自定义圆弧进度条(半圆进度条) 圆弧渐变色进度条带指示 圆弧宽高可自由修改
    PHP反序列化简单使用
    第一章操作系统引论
    Yunfly 一款高效、性能优异的 node.js web 框架
    算法笔记(一)
  • 原文地址:https://blog.csdn.net/weixin_43544179/article/details/133375755