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

时间:2010-10-10 20:31:38

标签: java c++ android java-native-interface android-ndk

所以我正在编写一个使用大型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 ++访问此方法。

2 个答案:

答案 0 :(得分:6)

coutprintf 的C ++调用将不会在LogCat输出中显示。有两种解决方案。

  1. 使用NDK提供的日志记录宏,允许您将消息记录到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!");

  2. 捕获程序的标准输出/标准错误并将其汇入LogCat。来自Android Debug Bridge页面:

      

    查看stdout和stderr

         

    默认情况下,Android系统将stdout和stderr(System.out和System.err)输出发送到/ dev / null。在运行Dalvik VM的进程中,您可以让系统将输出的副本写入日志文件。在这种情况下,系统使用日志标记stdout和stderr将消息写入日志,两者都具有优先级I.

         

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

      $ adb shell stop
      $ adb shell setprop log.redirect-stdio true
      $ adb shell start
    
         

    系统会保留此设置,直到您终止仿真器/设备实例。要在模拟器/设备实例上将该设置用作默认设置,可以在设备上向/data/local.prop添加条目。

答案 1 :(得分:0)

记录位于“#include”头文件中。

要链接.so,请在您的make文件中放置“LOCAL_LDLIBS:= -L $(SYSROOT)/ usr / lib -llog”。