`
碧海山城
  • 浏览: 190677 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Effective Java(一)

阅读更多
1. 创建和销毁对象

1) 考虑用静态工厂方法代替构造函数

   对于一个类,获得它的实例最常用的方法是提供一个共有的构造函数。但是有时候我们也可以为这个类提供一个简单的静态工厂方法(static factory method)。

   静态工厂方法可以比构造方法更为清楚的表达要创建的类的意义,它每次被调用的时候,不要求非要创建一个新的对象,它还可以返回一个原返回类型的子类型对象。

    有两个静态方法的名字已经非常流行了:
  1.valueOf:该方法返回的实例与它的参数具有同样的值。使用这个名字的静态工厂方法是一些非常有效的类型转换操作符。

  2.getInstance:返回的实例是由方法的参数来描述的,对于singleton的情形,该方法返回唯一的实例。

2) 使用私有构造函数强化singleton属性

    Singleton类指只能实例化一次。Singleton通常用来代表那些本质上具有唯一性的系统组件。
     实现Singleton有两种方法。这两种方法都是把构造函数保持为私有,并且提供一个静态成员,以便允许客户能够访问该类的唯一实例。

3) 通过私有构造函数强化不可实例化的能力

     有些情况下,可能会编写出只包含静态方法和静态域的类。这样的类不希望被实例化,但是缺少显示构造函数的情况下,编译器会自动提供一个共有的,无参 的默认构造函数。

     如果这个类允许其他应用程序new语句构造它的实例,但不允许拥有子类,那么就把类申明为final类型。
     如果一个类既不允许其他应用程序鼓噪它的实例,又不允许拥有子类,那么把构造方法声明为private类型。


4) 避免创建重复的对象

     重复使用同一个对象,而不是每次需要的时候就创建一个功能上等价的新对象,通常前者更为合适。
对于提供了静态工厂方法和构造函数的非可变类,可以利用静态工厂方法而不是构造函数,以避免创建重复的对象。比如Boolean.valueOf(String)

5) 消除过期对象的引用

     一般而言,只要一个类管理自己它的内存,程序员就应该警惕内存泄露问题。一旦一个元素被释放,则该元素中的对象引用应该被清空。

6) 避免使用终结函数

     我们不应该依赖一个终结函数来更新关键性的永久状态。System.gc和System
.runFinalization并不保证终结函数一定会被执行。通常,我们需要提供一个显示的终止方法,既try  Finally结合

2. 对于所有对象都通用的方法

1) 改写equals的时候遵守通用约定


     在改写equals方法的时候应该遵循:
          自反性
          对称性
          传递性
          一致性

3) 改写equals时总是要改写hashCode

     在每个改写equals方法的类中,必须也要改写hashCode方法,相等的对象必须具有相等的散列码

4) 总要改写toString

     提供一些好的toStirng实现,可以试一个类表达的更加清楚的信息

5) 谨慎地改写clone

     所有实现了Cloneable接口的类都应该有一个共有的方法改写clone,比共有方法先调用super.clone。然后修正任何需要的域

6) 考虑实现Comparable接口

3.类和接口

1) 使类和成员的可访问能力最小化

     一个设计良好的模块会隐藏所有实现的细节,把它的API与实现清晰隔离起来,它可以有效地接触一个系统中个模块的耦合关系,使得这邪恶模块可以被独立的开发测试。
应该尽可能使每一个类或成员不被外界访问

2) 支持非可变性

     为了使一个类成为非可变类,要遵循一下几条原则
     1. 不要提供任何会修改对象的方法
     2. 保证没有可被子类改写的方法
     3. 使所有的域都是final
     4. 使所有域都是私有的
     5. 保证对于任何可变数组的互斥访问。如果你的类具有指向可变对象的域,则必须确保该类的客户无法获得指向这些对象的引用。

     即使你不能将一个类做成非可变类,那么你任然应该尽可能地限制它的可变性。

3) 复合优先于继承

     与方法调用不同的是,继承打破了封装性,会照成一系列令人难以置信的问题,作者提到了一个非常形象的HashSet的add和addAll的例子。避免这些问题,可以不扩展已有的类,而是在新的类中增加一个私有域,它引用了这个已有类的实例,这种设计称为复合,新类中的每个实例方法都是=可以调用被包含的已有实例中对应的方法,并返回它的结果。

     只有当子类真正是超类时的”子类型”时,继承才是合适的。

4) 要么专门为继承而设计,并给出文档说明,要么禁止继承

5) 接口优于抽象类

     已有的类和容易被更新,以实现新的接口。
     接口是定义混合类型的理想选择
     接口使得我们可以构造出非层次结构的类型框架
     接口使得安全地增加一个类成为可能

6) 接口只被用于定义类型

     有一种接口被称为常量接口,这样的接口没有包含任何方法,它只包含静态的final域,每个域都导出一个常量。这种模式是对接口的不良使用。一个类要在内部使用某些常量,这纯粹是实现细节。

7) 优先考虑静态成员类
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics