|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
封装,继续与多态是OOP的三个核心本质。 Method-call(函数调用)绑定方法: 假如绑定动作发生于程序执行前(由编译器和连接器完成),成为"先期绑定(early binding)" 绑定动作将在执行期才根据对象型别尔进行,称为后期绑定late binding,或者执行期绑定run-time binding,或者动态绑定dynamic binding. Java运用RTTI(run-time type identification)技术来支持动态绑定. 上一章提到的final要害字修饰函数有两个作用:1是从设计上考虑禁止该method被覆盖,2是从效率上考虑告诉编译器可以"关闭"动态绑定,于是编译器便得以为final method call产生效率较佳的程序代码.不过大多数时候这么做并不会为你的程序带来整体效能提升.所以最好还是处于设计上的考虑来决定是否使用final,而不要企图用final来改善效率. override与overload在语法上只有微小的差别,但是语义上却108000里.一定要注重不要疏忽写错了.假如这个问题被埋藏于大型程序中,找出这个问题的难度可想而知有多高! abstract要害字:为了产生共同接口或者禁止生成base class的实例,可以使用抽象类. 含有abstract methods(抽象函数)的类称为abstract class.假如class含有单一或多个abstract methods,便需要以要害字abstract作为这个class的修饰词.否则编译器会发出错误信息. 我们也可以将不含任何abstract methods的class声明为abstract.假如你不希望你所撰写的class被产生出任何实体,但这个class又不具备"拥有abstract methods"的实际理由时,这项性质便极为有用. 构造函数(Constructors)和多态(polymorphism) 在某个对象生成的时候整个继续链上的构造函数都会被调用到,否则整个对象便无法建构成功. 继续与finalize() 当你使用组合技术来写新的class,你不需要烦恼他的成员对象的终止(finalizing)问题.每个成员都是独立对象,因此会被垃圾回收器回收并终止.不过在继续关系中,假如你有某些特殊的清理动作(cleanup)得在垃圾回收时候进行,你就得在derived class中复写finalize(),同时千万别忘了调用base class的finalize().即super.finalize(). plymorphic mehtods在构造函数中的行为 --是很难预料的:)动脑想一想吧.这里是臭虫多产地带.而就观念而言,构造函数的任务是让对象从无到有(这很难被视为一般性工作).因此,撰写构造函数时,一条原则是:"尽可能简朴地让对象进入准确状态.假如可以的话,别调用任何函数".构造函数中唯一可以安全调用的函数便是"base class中的final 函数"(这对private 函数来说相同成立,因为他们天生就是final).此类函数无法被复写,也就不会产生含混不清的问题了. 纯粹继续(pure inheritance) vs. 扩充(extension): IS-a vs. IS-like-a 向下转型(downcasting)与RTTI RTTI比单纯的转型包含了更多内涵.举例而言:有个方式可以让你在尝试向下转型之前,先取得你所处理的型别. 貌似前面的章节有提到:成员函数不许调用构造函数,现在构造函数对成员函数的调用上我们也尽量加以限制了.... -------------------------------------------------------------------------------- 返回类别: 教程 上一教程: 【Java】命令行参数的获取及判定 下一教程: Java混淆编译器(转apusic.com) 您可以阅读与"《Java编程思想》(第二版)第7章:多态(polymorphism)"相关的教程: · 《Java编程思想》(第二版)第07章:多态(polymorphism) · 《Java编程思想》(第二版)第6:重复运用classes · 《Java编程思想》(第二版)第08章:接口与内隐类 · 《Java编程思想》(第二版)第4章:初始化和清理 · 《Java编程思想》(第二版)第6章:重复运用classes |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |