How to get “printf” messages written in NDK application?

use __android_log_print() instead. You have to include header <android/log.h>

Sample Example. __android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "\n this is log messge \n");

You can also use format specifier like printf –

__android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "Need to print : %d %s",int_var, str_var);

Make sure you also link against the logging library, in your Android.mk file:

  LOCAL_LDLIBS := -llog

Ohh.. forgot .. The output will be shown in Logcat with tag LOG_TAG

Easy Approach

Add the following lines to your common header file.

#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

Now just call LOGD("Hello world") or LOGE("Number = %d", any_int) like printf in c.

Don’t forget to include the common header file.

Remove the logging

If you define LOGD(...) empty, all logs will be gone. Just comment after LOGD(...).

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

Leave a Comment

Hata!: SQLSTATE[HY000] [1045] Access denied for user 'divattrend_liink'@'localhost' (using password: YES)