第06周 预习:接口与多态
课前问题列表:
一.回顾以前数据结构的知识,所有排序算法的基本操作是什么?这个基本操作和Comparable接口又有什么关系?这个基本操作得到的结果有哪几种?
答:所有排序算法的基本操作都是比较。Comparable接口可以实现于大部分需要用到比较操作的类中。这个基本操作得到的结果由三种:大于、等于、小于,用int型的返回值表示便是 n(n>0)、0、n(n<0)。
二.详细描述:为什么某个类实现了Comparable接口,就可以对该类的集合(如数组、ArrayList)使用Arrays.sort进行排序?Comparator接口相较于Comparable接口有什么优势?
答:
public interface Comparable<T> {
public int compareTo(T o);
}
当类实现了Comparable接口后,便可以调用该接口中的compareTo()方法对集合中的元素进行比较,而Arrays.sort只需要明确的比较方法就可以对集合中的元素进行排序
在使用Comparable接口时,我们只能把类中某一项确定属性用于比较,而改用Comparator接口后,我们可以就类中的多项属性做出优先性不同的比较。
三.你觉得为什么有了抽象类还需要接口?接口相较于继承有什么不同,体现了什么关系?
-
原因:
(1)一个类可以包含多个接口,却只能从属于一个抽象类,从高内聚,低耦合的角度来讲多使用接口更有利于代码的高效性和简洁性。
(2)抽象类多是对于对象属性的抽象化,而接口则是一种行为规范,俩者应用范围不同。 -
不同:
(1)抽象类中可以存在非抽象的方法,可接口不能存在非抽象的方法,并且接口里面的方法只是一个声明,必须用 public abstract来修饰,没有具体的实现。
(2)抽象方法中的成员变量可以被不同的修饰符修饰,而接口中的成员变量默认都是静态常量。
(3)接口必须通过实现来完成,而抽象类是通过继承来完成的。 -
关系:
(1)类与类之间是继承关系,类与接口之间是实现关系。