Come ottenere i messaggi printf scritti nell'applicazione NDK?

Come ottenere i messaggi printf scritti nell'applicazione NDK?


se sto definendo tale funzione nel file java


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

quindi ho bisogno di codificare nel file 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);
}

quindi da dove questo printf lo stamperà messaggio?
Nel logcate non ho capito?


Come posso eseguire il debug di qualsiasi applicazione NDK inserendo messaggi di registro?


Risposte:


usa __android_log_print() invece. Devi includere l'intestazione <android/log.h>


Esempio di esempio. __android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "\n this is log messge \n");


Puoi anche usare identificatore di formato come printf -


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

Assicurati di collegarti anche alla libreria di registrazione, nel tuo file Android.mk:


  LOCAL_LDLIBS := -llog

Ohh.. dimenticato .. L'output verrà mostrato in Logcat con tag LOG_TAG


Approccio facile


Aggiungi le seguenti righe al tuo file di intestazione comune.


#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

Ora chiama solo LOGD("Hello world") or LOGE("Number = %d", any_int) come printf in c .


Non dimenticare di includere il file di intestazione comune.


Rimuovi la registrazione


Se definisci LOGD(...) vuoto, tutti i registri saranno spariti. Commenta solo dopo LOGD(...) .


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