4

我用 swi-prolog 开发了一个 prolog 程序,并使用带有 JPL.jar 的常规 java 为它附加了一个接口,它运行得很好。

现在我想对 android 移动界面而不是 java 桌面界面做同样的事情。所以我创建了一个 android 应用程序,将 JPL 添加为外部 jar 并像之前一样调用 prolog 文件。代码中没有显示错误。

但是当我将它作为 android 应用程序运行时,它说 jpl.query$1 找不到。

这是日志猫

08-21 17:36:35.782: D/dalvikvm(659): DexOpt: unable to opt direct call 0x0cd8 at 0x08 in Ljpl/Query;.abort
08-21 17:36:35.812: W/dalvikvm(659): Exception Ljava/lang/UnsatisfiedLinkError; thrown while initializing Ljpl/fli/Prolog;
08-21 17:36:35.812: D/AndroidRuntime(659): Shutting down VM
08-21 17:36:35.822: W/dalvikvm(659): threadid=1: thread exiting with uncaught exception (group=0x40a13300)
08-21 17:36:35.916: E/AndroidRuntime(659): FATAL EXCEPTION: main
08-21 17:36:35.916: E/AndroidRuntime(659): java.lang.ExceptionInInitializerError
08-21 17:36:35.916: E/AndroidRuntime(659):  at jpl.Query.open(Query.java:286)
08-21 17:36:35.916: E/AndroidRuntime(659):  at jpl.Util.textToTerm(Util.java:162)
08-21 17:36:35.916: E/AndroidRuntime(659):  at jpl.Query.<init>(Query.java:198)
08-21 17:36:35.916: E/AndroidRuntime(659):  at com.example.trtest.swi.main(swi.java:21)
08-21 17:36:35.916: E/AndroidRuntime(659):  at com.example.trtest.MainActivity$1.onClick(MainActivity.java:70)
------
----

08-21 17:36:35.916: E/AndroidRuntime(659): Caused by: java.lang.UnsatisfiedLinkError: Couldn't load jpl: findLibrary returned null
08-21 17:36:35.916: E/AndroidRuntime(659):  at java.lang.Runtime.loadLibrary(Runtime.java:365)
08-21 17:36:35.916: E/AndroidRuntime(659):  at java.lang.System.loadLibrary(System.java:535)
08-21 17:36:35.916: E/AndroidRuntime(659):  at jpl.JPL.loadNativeLibrary(JPL.java:100)
08-21 17:36:35.916: E/AndroidRuntime(659):  at jpl.fli.Prolog.<clinit>(Prolog.java:85)
...

那么错误可能是什么。

我发现有人说 JPL(swi prolog) 不能在 android 中使用,这是真的。

我该怎么做才能让我的 prolog 应用程序在 android 上运行

谢谢玛西

4

1 回答 1

4

SWI-Prolog 开发人员 Jan Wielemaker 最近在邮件列表中发布了在 Android 设备上使用 SWI-Prolog 的一些进展。请参阅[SWIPL] 节日礼物:Android 上的 SWI-Prolog

于 2013-08-21T15:00:18.907 回答