7

我正在尝试编写我的第一个库,但我仍然遇到一些设计问题。

我的库需要很多配置,我已经为其创建了接口和默认Impl类,但现在我的库需要与外部调用进行大量交互。这也是通过接口完成的,但我感觉用户被迫覆盖太多的方法,这些方法只返回一些默认错误甚至null. 有没有更好的方法让所有这些“你可以但你不必实现”部分更具可选性?

4

2 回答 2

10

即使您创建了一个接口,创建一个抽象基类也很有意义,您的库的用户可以扩展该基类以实现该接口。

抽象基类可以提供方法的默认实现,因此您的库用户不需要自己创建这些方法。它还可以定义 API 用户在创建具体子类时必须实现的抽象方法。

public abstract class MyBaseClass implements MyInterface {
    // abstract method 
    // anyone who extends must implement this    
    public abstract void myMethod1();

    // default error implementation
    // overriding is optional, but if used it will throw an error
    public void myMethod2() {
        throw new UnsupportedOperationException();
    }

    // default implementation that subclasses may find useful:
    public void doBothMethods() {
        myMethod1();
        myMethod2();
    }
}
于 2012-03-21T01:26:30.607 回答
2

这当然是一个没有理想方法的领域。它已被认可,并已使用公设辩护人方法解决。该链接将带您进入(官方)语言增强提案。

所以我建议你坚持使用接口并使用静态库方法提供每个方法的默认实现。这样,您就可以在 jummy 防御者方法优点可用时做好准备。

于 2012-03-21T01:51:39.253 回答