轻松切换java库的两个不同实现?

时间:2013-01-19 22:13:04

标签: java

我目前正在开发一个使用第三方库来管理硬件的项目。

我希望创建一个提供相同界面的替代库,但不是控制实际硬件,而是提供一个漂亮的假GUI。优选地,这可以通过更换罐来完成。

问题是所有第三方代码都在名称空间edu.edu.wpi.first.wpilibj中,当然我的库的名称空间也会非常不同。

在java中提供相同接口的两个库之间是否有任何方法可以轻松切换实现?

2 个答案:

答案 0 :(得分:2)

是的,有设计模式可以做到这一点。

您可以查看策略模式。

更好的是,您可以查看Dependency injection

您可以使用Google Guice作为容器,并根据您的配置,在运行时,您的实现可以在使用N库之间切换。

在一天结束时,你需要围绕一些抽象包装这些库。

这是一个例子:

interface ISomeOperation{
    void process();
}

class ThatUsesTheWPILIBJ implements ISomeOperation{

    void process(){
      //use library here
    }

}

class ThatUsesYourMock implements ISomeOperation{
    void process(){
      //use your mock here
    }
}


public YourUIClass{

    private ISomeOperation _operatingClass;


    public YourUIClass(ISomeOperation  operatingClass){

        _operatingClass = operatingClass;
    }

    public void render(){
        _operatingClass.process();
    }
}

现在您需要做的就是接线。看看google guice configuraion。

答案 1 :(得分:1)

是。 ServiceLoader。 它允许通过在类路径中放置jar(或通过某种配置)来切换实现。 但它对现有代码没有帮助。 (但是一旦完成,切换到任何其他实现都很容易。

它易于使用它的库,但如果库不使用它,则很难引入服务加载。您需要创建服务加载包装器。如果另一个库使用原始库,您还需要更改并重新编译它。

另一种方法是将它放在与原始库相同的包中并镜像其公共接口。但这很难看。