征上有很大的差别:考虑使用几个类
(7) 让一切东西都尽可能地"私有"--private。可使库的某一部分"公共化"(一个 方法、类或者一个字段等等),就永远不能把它拿出。若强行拿出,就可能破 坏其他人现有的代码,使他们不得不重新编写和设计。若只公布自己必须公布 的,就可放
心大胆地改变其他任何东西。在多线程环境中,隐私是特别重要的 一个因素--只有private字段才能在非同步使用的情况下受到保护。
not necessary , pretotect or package level also fine in most case
(8) 谨惕"巨大对象综合症"。对一些习惯于顺序编程思维、且初涉OOP领域的新 手,往往喜欢先写一个顺序执行的程序,再把它嵌入一个或两个巨大的对象 里。根据编程原理,对象表达的应该是应用程序的概念,而非应用程序本身。
(9) 若不得已进行一些不太雅观的编程,至少应该把那些代码置于一个类的内 部。
(10) 任何时候只要发现类与类之间结合得非常紧密,就需要考虑是否采用内部 类,从而改善编码及维护工作(参见第14章14.1.2小节的"用内部类改进代 码")。
(11) 尽可能细致地加上注释,并用javadoc注释
文档语法生成自己的程序文档。
(12) 避免使用"魔术数字",这些数字很难与代码很好地配合。如以后需要修改 它,无疑会成为一场噩梦,因为根本不知道"100"到底是指"数组大小"还是"其 他全然不同的东西"。所以,我们应创建一个常数,并为其使用具有说服力的描 述性名称,并在整个程序中都采用常数标识符。这样可使程序更易理解以及更 易维护。
(13) 涉及构建器和异常的时候,通常希望重新丢弃在构建器中捕获的任何异常- -如果它造成了那个对象的创建失败。这样一来,调用者就不会以为那个对象已 正确地创建,从而盲目地继续。
(14) 当客户程序员用完对象以后,若你的类要求进行任何清除工作,可考虑将 清除代码置于一个良好定义的方法里,采用类似于cleanup()这样的名字,明确 表明自己的用途。除此以外,可在类内放置一个boolean(布尔)标记,指出 对象是否已被清除。在类的finalize()方法里,请确定对象已被清除,并已丢弃 了从RuntimeException继承的一个类(如果还没有的话),从而指出一个编程 错误。在采取象这样的方案之前,请确定finalize()能够在自己的系统中工作 (可能需要调用System.runFinalizersOnExit(true),从而确保这一行为)。
(15) 在一个特定的作用域内,若一个对象必须清除(非由垃圾收集机制处 理),请采用下述方法:初始化对象;若成功,则立即进入一个含有finally从 句的try块,开始清除工作。
(16) 若在初始化过程中需要覆盖(取消)finalize(),请记住调用 super.finalize()(若Object属于我们的直接超类,则无此必要)。在对finalize() 进行覆盖的过程中,对super.finalize()的调用应属于最后一个行动,而不应是第 一个行动,这样可确保在需要基础类组件的时候它们依然有效。
(17) 创建大小固定的对象集合时,请将
它们传输至一个数组(若准备从一个方 法里返回这个集合,更应如此操作)。这样一来,我们就可享受到数组在编译 期进行类型检查的好处。此外,为使用它们,数组的接收者也许并不需要将对 象"造型"到数组里。
(18) 尽量使用interfaces,不要使用abstract类。若已知某样东西准备成为一个 基础类,那么第一个选择应是将其变成一个interface(接口)。只有在不得不 使用方法定义或者成员变量的时候,才需要将其变成一个abstract(抽象) 类。接口主要描述了客户希望做什么事情,而一个类则致力于(或允许)具体 的实施细节。
they are total diffrent ,
(19) 在构建器内部,只进行那些将对象设为正确状态所需的工作。尽可能地避 免调用其他方法,因为那些方法可能被其他人覆盖或取消,从而在构建过程中 产生不可预知的结果(参见第7章的详细说明)。
(20) 对象不应只是简单地容纳一些数据;它们的行为也应得到良好的定义。
(21) 在现成类的基础上创建新类时,请首先选择"新建"或"创作"。只有自己的设 计要求必须继承时,才应考虑这方面的问题。若在本来允许新建的场合使用了 继承,则整个设计会变得没有必要地复杂。
(22) 用继承及方法覆盖来表示行为间的差异,而用字段表示状态间的区别。一 个非常极端的例子是通过对不同类的继承来表示颜色,这是绝对应该避免的: 应直接使用一个"颜色"字段。
(23) 为避免编程时遇到麻烦,请保证在自己类路径指到的任何地方,每个名字 都仅对应一个类。否则,编译器可能先找到同名的另一个类,并
报告出错消 息。若怀疑自己碰到了类路径问题,请试试在类路径的每一个起点,
搜索一下 同名的.class文件。