0

我已经编译了一个用于 jni 的测试 dll。除了#include<jni.h> 之外,它实际上是完全空的。它编译得很好。我评论了其他所有内容以尝试使其正常工作。我使用了 gcc cygwin 版本和 -shared 和 eclipse。

这是加载库的类:

static
{
    final File f= new File(new File("res"), "mandc.dll");
    System.out.println(f.exists());
    System.load(f.getAbsolutePath());
    System.out.println("Loaded!");
}

//  public static native long mand(final double cx, final double cy,
//          final double jx, final double jy, long iter);

public static native void mand();

true 是最后打印的东西,证明错误在 true 和加载之间!如果我从 Eclipse 中运行,则会打印两条错误消息,但互联网不知道它们是什么。

消息:

2 [main] javaw <random number here> exception::handle: Exception: STATUS_STACK_OVERFLOW
667 [main] javaw <random number here> open_stackdumpfile: Dumping stack trace to javaw.exe.stackdump

堆栈转储没有提供信息。

Exception: STATUS_STACK_OVERFLOW at eip=61157C62
eax=0001C038 ebx=49E0834C ecx=49DE2ABC edx=49E27DB4 esi=49E07B2C edi=49E27B34
ebp=49E07ACC esp=49E07AB4 program=C:\Program Files\Java\jre7\bin\javaw.exe, pid 2688, thread main
cs=001B ds=0023 es=0023 fs=003B gs=0000 ss=0023
Stack trace:
Frame     Function  Args
49E07ACC  61157C62  (49E2D000, 49E27B3A, 49E27DB4, 00000008)
49E07AFC  6106C0B5  (49E27B3A, 49E27D78, 00000008, 49E27B2C)
49E27B4C  6106C6D1  (49E27B70, 00000C90, 00000000, 49E27DB4)
49E27DEC  6100584E  (49E27EBC, 611FBAF0, 611FBAEC, 49E27E2C)
49E27E3C  61005D28  (49E27FC3, 611FBAF0, 611FBAEC, 00000001)
49E2801C  61006F07  (00000000, 49E28058, 61006990, 49E2B268)
End of stack trace

当我从维基百科页面运行示例时,实验也失败了。它以同样的方式失败。

4

1 回答 1

0

问题已解决。我将工具链从 cygwin gcc 切换到 mingw gcc。为了支持这一点,我不得不从 cygwin 安装程序中安装额外的 mingw 包。

我猜cygwin与java不兼容。一个更好的错误信息将不胜感激。

于 2013-01-22T19:32:00.697 回答