50

如果我在 java 文件中定义这样的函数

  /** 
   * Adds two integers, returning their sum
   */
  public native int add( int v1, int v2 );

所以我需要在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);
}

那么这个 printf 将从哪里打印消息?在logcate中我不明白吗?

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

4

3 回答 3

110

改为使用__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);

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

  LOCAL_LDLIBS := -llog

哦..忘了..输出将显示在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

LOGD("Hello world") or LOGE("Number = %d", any_int)现在只需调用printf in c.

不要忘记包含通用头文件。

删除日志记录

如果定义为LOGD(...)空,则所有日志都将消失。之后评论就好LOGD(...)

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

于 2012-04-23T05:25:10.827 回答
17

有两种选择:

1) 将 printf 替换为 __android_log_print。您可以使用代码开头的定义轻松完成此操作:

#define printf(...) __android_log_print(ANDROID_LOG_DEBUG, "TAG", __VA_ARGS__);

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

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

于 2012-04-23T05:53:33.997 回答
7

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

$ adb shell 

$ su 

$ stop

$ setprop log.redirect-stdio true

$ start

完毕!

于 2014-06-20T02:35:57.480 回答