《Thinking In Java·第 1 章对象入门》
第 1 章约20页,是对面向对象的程序设计(OOP)的一个综述。按照其前言所述:
“其中包括对“什么是对象”之类的基本问题的回答,并讲述了接口与实现、抽象与封装、消息与函数、继承与合成以及非常重要的多形性的概念。这一章会向大家提出一些对象创建的基本问题,比如构建器、对象存在于何处、创建好后把它们置于什么地方以及魔术般的垃圾收集器(能够清除不再需要的对象)。要介绍的另一些问题还包括通过违例实现的错误控制机制、反应灵敏的用户界面的多线程处理以及连网和因特网等等。大家也会从中了解到是什么使得Java 如此特别,它为什么取得了这么大的成功,以及与面向对象的分析与设计有关的问题。”
整体上看,1.OOP的各种概念大致介绍一下;2.对象的生命周期问题;3.另一些问题。
注:【】中是该书的摘录,而【page xx 】是《编程导论》的相关摘录。
【面向对象编程(OOP)具有多方面的吸引力。……】事实上,他的意思是讲 面向对象技术或面向对象编程范式的好处而非OOP,涵盖OOA、OOD等。
【思考对象的时候,需要采用形象思维,而不是程序化的思维。……】在《编程导论·1.1.3 面向对象》中,使用 隐喻、符合人们日常生活中的一些处事习惯、我服务故我在、客户与服务器等,强调"面向对象技术基本愿望:希望在软件开发中,问题域的建模和解域的构建能够符合人类在日常生活中养成的思考习惯、生活习惯。程序员能够按照自己的日常生活经验进行软件开发"。而该书这里一带而过,主要说明库的事情。
翻译我就不吐槽了,这一段最好不要看中文版的。刚才我下了TIJ3rd。
1.【所有编程语言的最终目的都是提供一种“抽象”方法。....】本节稍对问题域和解域的映射加以介绍,而面向对象技术,正如上面已经说明的:问题域的建模和解域的构建...
有人说,学习面向对象技术的第一个词,就应该是抽象,同意。但是,什么是抽象?
这一段写得相当的唬人,如果说TIJ偏重于介绍面向对象的“思想”,我看这一段比较像!而且因为本节是1.1,读者会以为后面会展开,事实上,TIJ嘎然而止。
【《编程导论(Java)》p93 抽象发生在编程的各个方面,大致上分为功能抽象(functional/process abstraction)和数据抽象(data abstraction) ,以及对象抽象(object abstraction)。】所以,《编程导论(Java)》中编写了第3章功能抽象、第4章数据抽象。如果单纯讨论抽象,在《编程导论(Java)》1.1.1 问题域和解域中。
图 1-1 问题域和解域中的对象
【《编程导论(Java)》p24
图1-1简略的表达了问题域和解域之间的关系。其中两次地使用了抽象(abstract)这一词汇。
抽象既用作一个过程/活动,也用作一个结果/实体。
作为活动(动词),抽象意味着从一个或一组事实、数据、现象中提取(v. extract/ abstract)主要的细节而忽略非主要的细节。抽象是人类应对/控制复杂性的常用技术。例如对一群dogs加以抽象,按照需求可能仅关心狗的名字、年龄等,而忽略其出生地、外貌特征、饮食习惯等。最典型的例子是牛顿物理学中的质点,不考虑物体本身的形状和大小,把质量看作集中在一点上;再例如几何中的点、线、三角形等等。简言之,抽象即简化或理想化。形象地说,抽象就是舍得——有舍才有得。
作为(理论)实体(名词),抽象意味着从许多具有相同性质的、重复出现的事实/数据/现象中获得的类别性的概念、规律性的结论、数学公式、模型等表达形式。最基础的例子就是概念/名词,类是具体物体的抽象。再如,通过归纳或提炼(或证明),可以将程序的各种各样的语句抽象成三种基本流程结构。
】所以,在说道“抽象、继承、多态”时,这个抽象和类、概念、名词是近义词。
2.【Alan Kay 总结了Smalltalk 的五大基本特征……】我不太在意这五大基本特征,而且也不喜欢tij在五大基本特征的附加说明。但是,在《编程导论》图1-5艾伦•凯 面向对象之父(之一)前的★,和1.1标题中,强调了凯的名言:计算就是模拟。
3.【这一特性称为对象的“可替换性”,是OOP 最重要的概念之一。】嗯。我把LSP作为面向对象的三大基石,2.1.1 里氏替换原则、2.1.4 访问修饰符与继承·3. 继承的分类,以及继承多态都围绕LSP。不知道TIJ在后面会不会如此展开呢?
1.【亚里士多德或许是认真研究“类型”概念的第一人……】其实,亚里士多德是唯物的,而他的老师柏拉图(Plato)的理念论,正好适用于软件的解域。
2.【有些人进行了进一步的区分,他们强调“类型”决定了接口,而“类”是那个接口的一种特殊实现方式】。这个“接口”,我在4.1数据抽象的含义·4.1.2 类的接口中称为类的接口。【p133 类的接口指外界对象能够访问的、类所定义的接口的集合。使用访问修饰符限定类的接口,这一机制称为封装,在[第6章封装]中详细介绍。
绝大多数情况下,可以视class为一种type。例如,在[2.2.2Java数据类型]中所给出的(数据)类型的概念,将类作为类类型。
在[2.1.1里氏替换原则]中介绍了子类(subclass)与子类型(subtype)的区别,那么,类(class)和类型(type) 又有什么差异呢?
差异表现在接口与实现的分离上。type是一个名称,它标识了类的接口。如果一个对象能够接受X类的接口的全部操作请求(方法调用),则称对象具有X类型。正是因为Java的子类能够满足父类的接口(尽管可以改写),所以子类的对象能够同时具有类层次中的多个类型。
类(class)则是接口和实现的综合体。类不仅仅定义了一种类型,也定义了对象的内部状态和方法的实现,以及不是接口的方法(如private方法)。简言之,类型是类的接口,类是类型+实现。】。差评!本节介绍封装和信息隐藏。本节写得不好,接口与实现分离 和封装 ,被他混为一谈。