如何获取在NDK应用程序中编写的"printf"消息?

Jee*_*tel 42 c java-native-interface logging android android-ndk

如果我在java文件中定义这样的功能

  /** 
   * Adds two integers, returning their sum
   */
  public native int add( int v1, int v2 );
Run Code Online (Sandbox Code Playgroud)

所以我需要在c文件中编码

JNIEXPORT jint JNICALL Java_com_marakana_NativeLib_add
  (JNIEnv * env, jobject obj, jint value1, jint value2) {

  printf("\n this is log messge \n");

        return (value1 + value2);
}
Run Code Online (Sandbox Code Playgroud)

然后从这个printf将打印它的消息?在logcate我不明白吗?

如何通过放置日志消息来调试任何NDK应用程序?

Sha*_*ful 99

使用__android_log_print()来代替.你必须包括标题<android/log.h>

示例示例. __android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "\n this is log messge \n");

您还可以使用printf等格式说明符 -

__android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "Need to print : %d %s",int_var, str_var);
Run Code Online (Sandbox Code Playgroud)

确保您还链接到Android.mk文件中的日志库:

  LOCAL_LDLIBS := -llog
Run Code Online (Sandbox Code Playgroud)

哦..忘了..输出将显示Logcat带标签LOG_TAG

简单方法

将以下行添加到公共头文件中.

#include <android/log.h>

#define  LOG_TAG    "your-log-tag"

#define  LOGD(...)  __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
#define  LOGE(...)  __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)
// If you want you can add other log definition for info, warning etc
Run Code Online (Sandbox Code Playgroud)

现在就像打电话LOGD("Hello world") or LOGE("Number = %d", any_int)一样printf in c.

不要忘记包含公共头文件.

删除日志记录

如果您定义为LOGD(...)空,则所有日志都将消失.只需评论一下LOGD(...).

#define LOGD(...) // __android_log..... rest of the code

  • 为了防止有人(例如我)使用Android Studio(当前我的是0.8.11),你将ldLibs"log"放在'ndk'标签内.这解决了对'__android_log_print'问题的未定义引用. (5认同)
  • 从Android Studio 1.4 Gradle 2.5开始,LOCAL_LDLIBS:= -llog已从Android.mk移至build.gradle - 使用'android.ndk {moduleName ="Your-jni"ldLibs + ="log"}'注意.gradle语法已经改变了2.5(你需要'+ =') (2认同)

Mār*_*iko 16

有两种选择:

1)用__android_log_print替换printf.您可以在代码开头定义时轻松完成此操作:

#define printf(...) __android_log_print(ANDROID_LOG_DEBUG, "TAG", __VA_ARGS__);
Run Code Online (Sandbox Code Playgroud)

当然,这将需要更改具有printf的所有源代码.

2)将stdout和stderr重定向到Android logcat(不确定这是否适用于非root设备):http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd


小智 5

不需要root设备,可以访问http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd,下面可以完美地工作.

$ adb shell 

$ su 

$ stop

$ setprop log.redirect-stdio true

$ start
Run Code Online (Sandbox Code Playgroud)

完成了!

  • 如果没有root访问权限,su命令将无效.!! (2认同)
  • 此方法仅适用于运行dalvik(4.4或更早版本)的Android版本,ART版本(5.0或更高版本)不支持log.redirect-stdio.来源:https://code.google.com/p/android/issues/detail?id = 165602 (2认同)