java - 从动态 Java 类路径导入 Java 类的 Matlab 编译器 MCC 错误

标签 java matlab classpath matlab-deployment mcc

如何让 mcc 识别来自用户提供的 Java 库的导入,或者简单地忽略无法解析的导入?

我有一个使用 Matlab 编译器构建的 Matlab 代码库,但是构建失败了,因为 mcc 在遇到 Java 类的 import 语句时出错在 Matlab 的动态类路径上的 JAR 中。我使用 mcc -a 选项将所有 JAR 文件包含在类路径中。代码在 IDE 中工作,我认为它会在部署的应用程序中工作,如果它只允许我构建的话。 (在 R2009b 下工作,它忽略了非 MCOS 类中的这些导入。)

这是一个简单的重现。此文件与 Google Guava 中的 guava-11.0.1.jar 位于同一目录中。

%file hello_world_with_import.m
function hello_world_with_import
import com.google.common.base.Stopwatch;
disp('Hello, world!');
end

在 Matlab 中运行它工作正常。但是构建它失败了。 (这里的 javaaddpath 在这个例子中并不是绝对必要的,因为错误的导入本身在普通的 Matlab 中并不是错误。只是展示它在实践中是如何工作的,以及我希望如何 mcc 捡起它。)

>> javaaddpath('guava-11.0.1.jar');
>> hello_world_with_import()
Hello, world!
>> mcc -m -a guava-11.0.1.jar hello_world_with_import
Error: File: C:\Temp\import_test\hello_world_with_import.m Line: 3 Column: 8 
Arguments to IMPORT must either end with ".*" 
 or else specify a fully qualified class name: "com.google.common.base.Stopwatch" fails this test. 
Unable to determine function name or input/output argument count for function  
in MATLAB file "hello_world_with_import".  
Please use MLINT to determine if this file contains errors. 
Error using mcc
Error executing mcc, return status = 1 (0x1).

这是在 Windows 上的 Matlab R2011b 中。


我的环境的一些背景。我的应用程序在动态类路径上有大约 40 个 JAR,它们混合了第三方库和我们自己的 Java 代码。它在单用户和多用户 Windows 计算机上部署到 50 多个用户。还有其他团体可能正在将其他 MCR 应用程序部署到相同的用户和机器。在任何机器上,不同的 MCR 应用程序可能由相同或不同的用户同时运行。我们每周发布一次,并且(主要是由于我们自己的 Java 代码发生了变化)至少有一个 JAR 文件对每个其他版本进行了更改。我需要一种可以在这种环境中工作的机制。


有什么建议吗?任何人都知道让 mcc 在编译步骤中将内容添加到其 java 类路径的好方法,或者只是忽略伪造的导入?我的后备计划是检查代码库并删除所有 Java 类的导入,这有点麻烦。


2012 年 12 月 2 日更新:我从 MathWorks 那里得知这已在 Matlab R2012b 中修复。 (但我不再使用 Matlab,因此无法亲自验证。)

更新 12/09/2014:我再次使用 Matlab (R2014b),Matlab 编译器现在包含已编译程序的动态类路径中的动态类路径上的 JAR。不过,它似乎并没有自动将 JAR 文件包含在存档中;您必须使用 mcc 命令行开关手动包含它们,或将它们作为“附加包含文件”添加到 Matlab Compiler 应用程序中。

最佳答案

在 MATLAB IDE 中执行的代码可以运行,因为 guava jar 文件已通过 javaaddpath 方法添加到“动态”类路径中。但是,当您使用 MCC 调用 MATLAB 编译器时,它不依赖于动态 java 类路径,而是“静态”java 类路径,它定义在:

$MATLABROOT/toolbox/local/classpath.txt

如果您在此处为您的 JAR 文件添加一个条目,那么 MCC 将能够解析您的 M 文件中的 IMPORT 行。

所以为了对此进行测试,我下载了 guava jar 文件并尝试了上述步骤。就像一个魅力。

此外,如果您阅读了 MATLAB 编译器的“疑难解答”部分,则会记录这种确切情况:

http://www.mathworks.com/help/toolbox/compiler/brtm1xm-8.html

从链接中引用:“导入语句正在引用 MATLAB 编译器(如果错误发生在编译时)或 MCR(如果错误发生在运行时)无法找到的 Java 类 ()。

要解决此问题,请确保包含 Java 类的 JAR 文件存储在 Java 类路径上的文件夹中。 (类路径见matlabroot/toolbox/local/classpath.txt。)如果运行时出错,在开发机器上运行时类路径存储在matlabroot/toolbox/local/classpath.txt中。”

关于java - 从动态 Java 类路径导入 Java 类的 Matlab 编译器 MCC 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9220675/

相关文章:

java - 使用 Java 和 Sax 解析某些 RSS 提要时遇到问题

matlab - 在 Matlab 中查找相等的行

Cloud9 IDE 上的 Java 打包

java - 如何指定系统独立类路径

java - 如何提及类路径

java - 使用类作为键插入哈希表的通用方法

java - Maven surefire 插件不在 xml 中包含用于通过测试的系统输出

matlab - 为什么 feval 会在 MATLAB 中返回 NaN

java - netty:启用 keep-alive 时,http 文件示例无法与 apache bench 一起使用

performance - 列出所有 n 对整数的最快解决方案?