3

我正在尝试将我的 Android 应用程序与使用 Free Pascal 编译的 JAR 链接。我收到以下构建错误:

[2012-09-14 16:08:38 - MyApp] Dx 
EXCEPTION FROM SIMULATION:
[2012-09-14 16:08:38 - MyApp] Dx local 0009: invalid

[2012-09-14 16:08:38 - Yarxi] Dx ...at bytecode offset 00015f2c
locals[0000]: Lcom/mypackage/$Core$$_fpc_nestedvars$70;
locals[0001]: I
locals[0002]: I
locals[0003]: I
locals[0004]: I
locals[0005]: I
locals[0006]: I
locals[0007]: I
locals[0008]: I
locals[0009]: <invalid>
locals[000a]: <invalid>
(..more locals... much more)
locals[06db]: <invalid>
stack[0003]: I
stack[0002]: I
stack[0001]: [I
stack[top0]: int{0x00000000 / 0}
...while working on block 5f23
...while working on method $MyMethod$944$FPR1:(Lcom/mypackage/$Core$$_fpc_nestedvars$70;)V
...while processing $MyMethod$944$FPR1 (Lcom/mypackage/$Core$$_fpc_nestedvars$70;)V
...while processing com/mypackage/Core.class

[2012-09-14 16:08:40 - MyApp] Dx 1 error; aborting
[2012-09-14 16:08:40 - MyApp] Conversion to Dalvik format failed with error 1

错误似乎是在某些时候,代码尝试读取未初始化的本地 0009。

现在,Pascal 不强制初始化局部变量。有可能一开始就省略了初始化。我保留了 Free Pascal 为我生成的 JVM 汇编文件。这些与 Jasmin 一起组装到类文件中。该文件很大 - 我不会在这里粘贴它。

有人可以帮我将错误点追溯到源头吗?错误位于字节码偏移量 00015f2c。有没有办法将其转换回汇编文件行号?

4

1 回答 1

2

解决。00015f2c(十进制的 89900)确实是方法中的字节码偏移量。我做了以下。

首先,我直接调用 Jasmin,传递生成的 .j 文件和 -g 选项(生成行号):

java -jar %JASM% -g Core.j

Free Pascal 本身不会发出 -g 。这给了我一个替代的 Core.class 文件,其中包含行号,行号相对于 FPC 生成的 .j 文件。然后我曾经javap将这个类反汇编成另一个 .j 文件:

"%JDKROOT%\javap" -l -c Core.class >Core_WithLines.j

但是这个新的 .j 文件包含每个单独命令的行号和偏移量。然后,我在违规方法中搜索了偏移量 89900(注意:由 生成的偏移量javap在 65536 处换行)。然后我查看了该方法主体下方的 LineNumberTable(偏移量和行号都换行),在源 Core.j 文件中找到了与该偏移量相对应的行号。回头看Core.j,有一条注释,里面包含了Pascal源码的行号。

确实,有一个函数调用传递了一个未初始化的变量——但作为一个var参数。

这个问题有点像 Pascal/JVM 边界问题。该变量未初始化,但它由 ref 传递到要从后者返回的函数中。编译器应该以某种方式将其抽象出来,恕我直言,但 FPC 没有。

于 2012-09-14T21:18:09.477 回答