代码改变世界

《Java程序猿面试笔试宝典》之组合与继承有什么差别

2017-04-22 15:27  tlnshuju  阅读(266)  评论(0编辑  收藏  举报

组合和继承是面向对象中两种代码复用的方式。

组合是指在新类里面创建原有类的对象,反复利用已有类的功能。继承是面向对象的主要特性之中的一个,它同意设计人员依据其他类的实现来定义一个类的实现。

组合和继承都同意在新的类中设置子对象(subobject),仅仅是组合是显式的,而继承则是隐式的。组合和继承存在着相应关系:组合中的总体类和继承中的子类相应。组合中的局部类和继承中的父类相应。

二者的差别在哪里呢?首先分析一个实例。Car表示汽车对象,Vehicle表示交通工具对象,Tire表示轮胎对象。三者的类关系下图 所看到的。


       从上图中能够看出。Car是Vehicle的一种,因此是一种继承关系(又被称为“is-a”关系)。而Car包括了多个Tire,因此是一种组合关系(又被称为“has-a”关系)。

事实上现方式例如以下:

继承

组合

class Verhicle{

}

class Car extends Verhicle{

 

}

class Tire{

}

class Car extends Verhicle{

       private Tire t=new Tire();

}

       既然继承和组合都能够实现代码的重用,那么在实际使用的时候又该怎样选择呢?普通情况下,遵循下面两点原则。

(1)       除非两个类之间是“is-a”的关系,否则不要轻易地使用继承,不要单纯地为了实现代码的重用而使用继承,由于过多地使用继承会破坏代码的可维护性。当父类被改动的时候,会影响到全部继承自它的子类,从而添加程序的维护难度与成本。

(2)       不要仅仅为了实现多态而使用继承,假设类之间没有“is-a”的关系。能够通过实现接口与组合的方式来达到同样的目的。设计模式中的策略模式能够非常好的说明这一点,採用接口与组合的方式比採用继承的方式具有更好的可扩展性。

由于Java语言仅仅支持单继承,假设想同一时候继承两个类或多个类。在Java中是无法直接实现的。

同一时候,在Java语言中。假设继承使用太多,也会让一个class里面的内容变得臃肿不堪。所以,在Java语言中。能使用组合的时候尽量不要使用继承。


出自新书《Java程序猿面试笔试宝典》官网