我有一组API类,它们只包含静态方法和一个私有构造函数,因此无法实例化它们.但是,我希望第三方开发人员能够修改API的行为以满足他们的需求.
这是我到目前为止的解决方案(通过静态setter方法的依赖注入).这是开发人员将使用的公共API类.如您所见,它依赖于StaticApiImpl.
public class StaticApi {
private static StaticApiImpl impl = new StaticApiImpl();
private StaticApi() {}
public static void setImpl(StaticApiImpl impl) {
StaticApi.impl = impl;
}
public static void doThing() {
impl.doThing();
}
}
这是我自己编写的默认API实现.
public class StaticApiImpl {
public void doThing() {
System.out.println("Do thing the default way.");
}
}
这是第三方可能编写的默认实现的假设扩展版本:
public class MyCustomStaticApiImpl extends StaticApiImpl {
@Override
public void doThing() {
System.out.println("Do thing differently.");
}
}
然后,开发人员只需在初始化插件时通过setter方法注入依赖项:
public void onLoad() throws Exception {
StaticApi.setImpl(new MyCustomStaticApiImpl());
}
我的问题是:这是正确的做法吗?是否有一些专门用于此类案例的设计模式,我还没有听说过?