如何在JNI中从C ++调用Java方法

因此,我正在编写一个使用大型c 库的Android应用。我可以正常工作,以便Java应用程序可以调用c 委托方法,但是我发现自己希望自己可以将来自c

的消息记录到Android日志中。从Java上这很容易,但是我不知道如何从c 调用Java方法。我的搜索找到了从c

打开jvm的方法,这根本不是我想要做的。理想情况下,我想将日志方法指针传递给c

,然后可以在需要时使用它。当然,Java不支持方法指针。我的java方法如下所示:

private void log(String s){

Log.i(Tag, s); // Android log

}

我只是不知道如何允许c ++访问此方法。

回答:

C ++来调用coutprintf不会出现 在logcat的输出。有两种解决方案。

  1. 使用NDK提供的Logging宏,该宏允许您将消息记录到LogCat。这对于您正在编写的新代码和包装器代码很有用,但是当您的库中充满了现有的调试语句时,效果就不好了。我定义宏如下:
    #define LOG_INFO(info) __android_log_write(ANDROID_LOG_INFO,"JNI",info)

    define LOG_ERROR(error) __android_log_write(ANDROID_LOG_ERROR,”JNI”,error)

然后在源代码中,我可以调用 LOG_INFO("Library is called!");

  1. 捕获程序的标准输出/标准错误,并将其合并到LogCat中。在“ Android调试桥”页面上:

查看stdout和stderr

默认情况下,Android系统将stdout和stderr(System.out和System.err)输出发送到/ dev /

null。在运行Dalvik

VM的进程中,您可以让系统将输出的副本写入日志文件。在这种情况下,系统将使用优先级为I的日志标签stdout和stderr将消息写入日志。

要以这种方式路由输出,请停止正在运行的仿真器/设备实例,然后使用shell命令setprop启用输出重定向。这是您的操作方式:

>       $ adb shell stop

$ adb shell setprop log.redirect-stdio true

$ adb shell start

在您终止仿真器/设备实例之前,系统将保留此设置。要将设置用作仿真器/设备实例上的默认设置,可以在设备上的/data/local.prop中添加一个条目。

以上是 如何在JNI中从C ++调用Java方法 的全部内容, 来源链接: utcz.com/qa/404345.html

回到顶部