好的,我有一个 Android 应用程序,我开始为该应用程序创建一个插件系统,以便开发人员可以编写内容提供程序,然后该应用程序可以使用这些内容提供程序来生成不同的内容,我不会完成整个过程,但一切正常所以:
1)
我创建了一个名为 com.myaddonlib
的库,我在我的项目中导入了这个库,其中有一个接口(interface)和不同的对象。
2)
现在开发人员可以在他的端创建一个简单的 Java 项目,导入库 com.myaddonlib
,并在他的主类上实现接口(interface),该类具有从库返回不同对象的方法。
3) 回到 android 应用程序,我可以加载开发人员创建的 .jar 文件(在将 classes.dex 添加到 jar 文件之后),使用 android DexClassLoader 我可以像这样加载实现的接口(interface):
DexClassLoader classloader = new DexClassLoader(jarFilePath, tempDirectory, null, context.getClass().getClassLoader());
Class classToLoad = classloader.loadClass("com.apackage.Addon");
其中 Addon
是由插件开发人员创建的类,它实现了位于名为 com.apackage
的包中的库的接口(interface)。
然后,我可以将库 com.myaddonlib
中的接口(interface)转换为 classToLoad
的新实例,并调用插件开发人员实现的函数。
现在的问题是我决定更新插件库并从类中删除一个变量,这意味着插件的类现在不同于更新库中的类(在应用程序中使用)。即使未使用更改的变量,也会导致应用程序崩溃而不会出现任何错误。仅仅是两个类不同这一事实(即使唯一的区别只是缺少一个变量)就会导致出现故障。现在这不是一个容易解释的过程,所以我可以理解,鉴于我的英语不好,有些人很难理解。 我的问题是我需要知道如何避免由于两端之一的库发生变化而导致的崩溃。以及在这种情况下 java 如何处理对象更改
最佳答案
我的解决方案并没有解决问题,而是确保它永远不会发生。您描述的问题类似于经典的服务器-客户端问题。您有一个服务器(在您的情况下是您正在开发的应用程序)和客户端(由开发人员编写的插件)。您可以定义具有许多功能的接口(interface)并以二进制结构传递数据。从流量/解析的角度来看,这会更有效,但是每当您更改服务器上的 API 时,您都必须更新所有客户端(否则可能会发生崩溃或其他问题)。
因此,为了解决服务器-客户端上的这个问题,许多人选择使用 HTTP 调用 JSON描述数据的对象。这种方式虽然效率较低,但可以添加API,同时支持多个客户端版本。
在 Android 中使用这种方法非常简单。定义具有两个函数和一个接口(interface)的 API:
public String sendDataToLibrary(String jsonString) {
// Parse data, perform operation and return a JSON string as the result
}
public interface GetDataFromLibrary {
String onDataFromLibrary(String jsonString);
}
public void init startLibrary(GetDataFromLibrary callback) {
// Set callback in library and call it whenever you have data that needs to be sent out from the library asynchronously
}
如您所见,如果您实现此接口(interface),您可以在库和插件之间传递任何数据,并且它永远不会改变,因此不会发生崩溃。一种改进可以是强制传递版本号以允许库支持多版本控制。
关于Java 反射处理库更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43691071/