java – 抽象类和接口在一起?

前端之家收集整理的这篇文章主要介绍了java – 抽象类和接口在一起?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一部分代码,其中一些类正在实现一个接口.

感觉正确,但是在小孩阶段中有一点重复 – 即3种方法.

所以这是尖叫出来使用抽象类.

我的问题是,在以下情况下是否有使用抽象类和接口的任何缺点:

>抽象类来实现接口和子类来扩展抽象类
>子类扩展抽象类并实现接口

要么

抽象类和接口是否应该像这样一起使用?

解决方法

将这两个一起使用是非常正常的.考虑例如JDK中的 AbstractList(实现列表)和 AbstractMap(实现Map).

我的膝盖反应本来是让抽象类实现接口,然后具体派生出来的具体类:

abstract class Base implements TheInterface {
    /* ...shared methods... */
}

class Concrete1 extends Base { }

class Concrete1 extends Base { }

但是,提出另一种可能性的问题让我想起了,我看不出有太多反对这样做的论据:

abstract class Base {
    /* ...shared methods... */
}

class Concrete1 extends Base implements TheInterface { }

class Concrete1 extends Base implements TheInterface { }

此外,我可以看到一个这样做的参数,具体来说它消除了抽象类和接口之间的耦合.如果您有另一个类需要Base提供的功能,但不需要实现该接口,则可以灵活地执行此操作.

还有第三个选项:组合.你根本不能有一个抽象类,而是实现接口的多个具体类在它们的实现中使用一个常用的助手类:

class Helper {
    /* ...shared methods... */
}

class Concrete1 implements TheInterface {
    /* ...uses instance of Helper */
}

class Concrete1 implements TheInterface {
    /* ...uses instance of Helper */
}

这具有同样的灵活性,以另一种形式.

猜你在找的Java相关文章