gpt4 book ai didi

java - 黑莓Java : Preprocessor directives don't remove dependencies

转载 作者:行者123 更新时间:2023-12-01 12:37:37 26 4
gpt4 key购买 nike

例如,可以为 OS 6.0 编译一个应用程序并在 5.0 设备上运行它,只要您不使用较新的 API,就可以(我刚刚在 2 分钟前进行了测试)以确保)。

我使用 eclipse 3.6 和最后一个 BB 插件来开发一个应用程序,我们仅在可用时才需要使用条形码扫描(API 6.0 及更高版本)。最干净的解决方案是在较低版本中不加载冲突的类。如果这是 Java SE,我会将条形码 API 的所有使用封装在一个类中(我们称之为 OS6Impl),同时创建一个默认的 OS5Impl,然后我会已在运行时使用反射实例化其中之一,具体取决于设备的操作系统级别。

但这只是 BB,这还不够,所以我们必须求助于预处理器指令并管理应用程序的 2 个不同版本。如果预处理器标志禁用新的 API 功能,则生成的预处理 OS6Impl.java 文件将删除所有内容。我可以通过查看 .preprocessed 文件夹内的文件并打开生成的 jar 文件来看到这一点,其中不存在 OS6Impl.class 文件。当标志启用新功能时,OS6Impl.java 文件内包含代码,并且 OS6Impl.class 文件包含在 jar 中。

这没问题,应该可以在使用 JRE 6 编译这两个版本的 OS5 和 OS6 设备上运行。但事实并非如此。预处理正常,该类不包含在 jar 中(因此它不应该包含在 cod 中),但是当我们在 5.0 设备中运行它时,它会显示一条错误消息(“找不到模块”)。该模块是“net_rim_barcodescanner”,我们打算仅使用它来扫描 6.0+ 设备中的条形码。

我必须编译 JRE 5.0 才能消除该错误。这很荒谬,因为正如我之前所说,为 6.0 编译的不使用较新 API 的代码能够在较低版本中运行。我已经多次验证,除了 OS6Impl.java 类之外,没有使用较新的 API 的导入,预处理器指令设置正确,并且每次之后都完成了清理和构建预处理器指令更改。安装每个 cod 后还重新启动了黑莓。

现在要编译一个或另一个版本,我们不仅要修改应用程序描述符中的指令,还要修改构建路径以将 JRE 切换到 5 或 6。

使用预处理器指令去除不兼容的代码时会添加什么样的依赖项?为什么在编译没有预处理器指令的兼容代码时不添加这些依赖项?预处理器不是在编译器之前运行的吗?

最佳答案

不,虽然某些程序可能有效,但并不保证所有程序都有效。原因和java拒绝加载高版本JDK编译的类是一样的。

让我解释一下。随着版本的每次更改,还会添加一些新的操作码和 VM 常量。这些操作码控制类文件的生成,而其他常量则在生成的 cod 文件中使用。如果较高版本的编译器在生成 cod 时生成任何这些操作码/常量,则较低版本的运行时将无法理解它们。

要了解差异,请查看 JDK bin 目录中 JDWP.jar 中的 net.rim.ide.core.VMConst 类。虽然 5.0 和 6.0 之间没有操作码差异,但添加了一些新的 VM 常量。在 7.0 中,添加了两个新的操作码。

因此,6.0 编译生成的 cod 有可能无法被 5.0 运行时理解。

如何针对不同操作系统进行编译:

将 Ant 与 BB Ant Tools 一起使用。然后您可以创建多个目标,使用不同的 JDK 一键编译。为不同的屏幕尺寸创建不同的构建目标以减少生成的 cod 文件的大小也变得非常容易。

关于java - 黑莓Java : Preprocessor directives don't remove dependencies,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25447487/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com