我目前正在开发一个使用第三方库来管理硬件的项目。
我希望创建一个提供相同界面的替代库,但不是控制实际硬件,而是提供一个漂亮的假GUI。优选地,这可以通过更换罐来完成。
问题是所有第三方代码都在名称空间edu.edu.wpi.first.wpilibj
中,当然我的库的名称空间也会非常不同。
在java中提供相同接口的两个库之间是否有任何方法可以轻松切换实现?
答案 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(或通过某种配置)来切换实现。 但它对现有代码没有帮助。 (但是一旦完成,切换到任何其他实现都很容易。
它易于使用它的库,但如果库不使用它,则很难引入服务加载。您需要创建服务加载包装器。如果另一个库使用原始库,您还需要更改并重新编译它。
另一种方法是将它放在与原始库相同的包中并镜像其公共接口。但这很难看。