继承是实现类重用的重要手段,但继承带来了一个最大的坏处:破坏封装。相比之下,组合也是实现类重用的重要方式,而采用组合方式来实现类重用则能提供更好的封装性。
1,使用继承的注意点
子类扩展父类时,子类可以从父类继承得到 Field 和 方法,如果访问权限允许,子类可以直接访问父类的 Field 和方法,相当于子类可以直接复用父类的 Field 和方法,确实非常方便。
继承带来了高度复用的同事,也带来了一个严重的问题:继承严重地破坏了父类的封装性。前面介绍封装时提到:每个类都应该封装它内部信息和实现细节,而只暴露必要的方法给其他类使用。但在继承关系中,子类可以直接访问父类的 Field (内部信息)和方法,从而造成了类和父类的严重耦合。
从这个角度来看,父类的实现细节对子类不再透明,子类可以访问父类的 Field 和方法,并可以改变父类方法的实现细节,从而导致子类可以恶意篡改父类的方法。
为了保证父类有良好的封装性,不会被子类随意改变,设计父类通常应该遵循如下规则。
尽量隐藏父类的内部数据。尽量把父类的所有 Field 都设置成 private 访问类型,不要让子类直接访问父类的 Field。
不要让子类可以随意访问、修改父类的方法。父类中那些仅为辅助其他的工具方法,应该使用 private 访问控制修饰符,让子类无法访问该方法;如果父类中的方法需要被外部类调用,则必须以 public 修饰,但又不希望子类重写该方法,可以使用 final修饰符来修饰该方法;如果希望父类的某个方法被子类重写,但不希望被其他类自由访问,则可以使用 protected 来修饰