2008-07-09 04:30:17
来自: franksxiong
(Trying to balance)
计算机程序的构造和解释(原书第2版)的评论



1. 涵盖面很广。从数据抽象、过程抽象、迭代、高阶函数等编程和控制系统复杂性的思想,到数据结构和算法,到编译器/解释器、编程语言设计。MIT这门课的课程讲义(在MIT OCW里可找到)里还增加了面向对象编程的内容。虽然很多内容涉及并不深入,但是这是MIT EECS(电子工程与计算机科学系)的第一门专业基础课(6.001),也就是说MIT计算机专业的学生在进入大学之后,在这门课之前没有上过其它编程、软件、计算机方面的课程。从这个角度看,起点是非常高的。其它大学的学生在倒腾C语言的时候,MIT的学生在思考设计语言和系统。
2. 用解释语言而不是编译语言来阐述思想,简化了数据类型、运行环境相关的一些细节,另外Scheme/Lisp有着极其简练、但功能极其强大和灵活的语法,这些都使阅读者更多地将精力集中在思想上,而不是语法细节上,颇为适合学习,只是Scheme的执行效率可能较低,表达力可能不够”丰富“,不一定适合于实际开发。
3. MIT OCW 6.001里有几个project,都很有意思。其中一个是设计一个类似于Google使用的web爬虫!虽然实际上没这么可怕,做了很多简化,集中在树的遍历与索引表的建立和查询上,但是仍然可以从中看出教授的视野和对学生的要求。
4. 现在MIT EECS已经取消了这门课,6.001的EECS介绍性功能被6.01和6.02两门课程替代,另外新增了6.005(软件),6.006(算法),是不是因为6.001起点太高或有点偏呢?(对于EE方向的学生来说似乎有点偏。)尽管如此,作为一门在MIT EECS教授了20多年的经典课程,仍然有其价值。
5. MIT EECS没有专门教授C、C++、Java等编程语言的课,一般都是要求学生用很短的时间自学。比如6.004要用到C,6.005要用到Java,6.006要用的Python,教授会要求学生在课程开始的几个星期内自学掌握这些语言。
6. SICP中译本翻译有些问题。比如表述符号(变量)和值的binding关系时,binding一词应翻译成“绑定”,而不是“约束”。
7. 最后发句牢骚:MIT Scheme相当难用,简直是石器时代的开发工具:)(指编辑和解释器,不是语言)。
上面说的MIT OCW 6.001网址:http://ocw.mit.edu/O cwWeb/Electrical-Eng ineering-and-Compute r-Science/6-001Sprin g-2005/CourseHome/in dex.htm
计算机程序的构造和解释(原书第2版)的评论




1. 涵盖面很广。从数据抽象、过程抽象、迭代、高阶函数等编程和控制系统复杂性的思想,到数据结构和算法,到编译器/解释器、编程语言设计。MIT这门课的课程讲义(在MIT OCW里可找到)里还增加了面向对象编程的内容。虽然很多内容涉及并不深入,但是这是MIT EECS(电子工程与计算机科学系)的第一门专业基础课(6.001),也就是说MIT计算机专业的学生在进入大学之后,在这门课之前没有上过其它编程、软件、计算机方面的课程。从这个角度看,起点是非常高的。其它大学的学生在倒腾C语言的时候,MIT的学生在思考设计语言和系统。
2. 用解释语言而不是编译语言来阐述思想,简化了数据类型、运行环境相关的一些细节,另外Scheme/Lisp有着极其简练、但功能极其强大和灵活的语法,这些都使阅读者更多地将精力集中在思想上,而不是语法细节上,颇为适合学习,只是Scheme的执行效率可能较低,表达力可能不够”丰富“,不一定适合于实际开发。
3. MIT OCW 6.001里有几个project,都很有意思。其中一个是设计一个类似于Google使用的web爬虫!虽然实际上没这么可怕,做了很多简化,集中在树的遍历与索引表的建立和查询上,但是仍然可以从中看出教授的视野和对学生的要求。
4. 现在MIT EECS已经取消了这门课,6.001的EECS介绍性功能被6.01和6.02两门课程替代,另外新增了6.005(软件),6.006(算法),是不是因为6.001起点太高或有点偏呢?(对于EE方向的学生来说似乎有点偏。)尽管如此,作为一门在MIT EECS教授了20多年的经典课程,仍然有其价值。
5. MIT EECS没有专门教授C、C++、Java等编程语言的课,一般都是要求学生用很短的时间自学。比如6.004要用到C,6.005要用到Java,6.006要用的Python,教授会要求学生在课程开始的几个星期内自学掌握这些语言。
6. SICP中译本翻译有些问题。比如表述符号(变量)和值的binding关系时,binding一词应翻译成“绑定”,而不是“约束”。
7. 最后发句牢骚:MIT Scheme相当难用,简直是石器时代的开发工具:)(指编辑和解释器,不是语言)。
上面说的MIT OCW 6.001网址:http://ocw.mit.edu/O
本评论版权属于作者franksxiong,并受法律保护。除非评论正文中另有声明,没有作者本人的书面许可任何人不得转载或使用整体或任何部分的内容。
作者: Harold Abelson, Gerald Jay Sussman, Julie Sussman
isbn: 7111135105
书名: 计算机程序的构造和解释(原书第2版)
页数: 473
定价: 45.0
出版社: 机械工业出版社
译者: 裘宗燕
装帧: 平装
出版年: 2004-02-01
又名: Structure and Interpretation of Computer Programs,Second Edition
franksxiong的其他评论 · · · · · ·
- (评百万大决定:世界是如何运作的?)
- (评苏菲的世界)
- (评你在为谁工作)
- (评Monsters, Inc.)
2008-07-09 20:23:29 三分
1. 起点确实有点高。但另一方面,SICP也是从最基本的开始讲起,进而引出赋值、面向对象等等的概念。如果什么都不懂就开始学C C++,既要考虑语言细节,又对递归赋值面向对象之类的概念都没什么了解,反而会走弯路。6. 我感觉总体翻译还凑合,挺通顺的……
其他的顶lz,剩下的就是感叹MIT之牛了
2008-07-12 07:45:47 hacker47
MIT的选择,不会错。2008-10-26 11:20:23 hacker47
关于Mit Scheme难用的问题,可以用PLT scheme,
网上有下载。
2009-02-19 17:26:59 fankaicn
好像现在MIT改用python入门了,应该说python还是很强大的,可以在很大程度上实现lisp里的抽象,同时代码方式也更容易为普通人接受2009-04-30 23:02:58 E.T
mit scheme 的编辑器还是挺好的(I Love Emacs~),不过整体就太差劲了……> 我来回应