Wie bekomme ich printf-Nachrichten, die in der NDK-Anwendung geschrieben werden?

Wie bekomme ich printf-Nachrichten, die in der NDK-Anwendung geschrieben werden?


wenn ich eine solche Funktion in einer Java-Datei definiere


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

Also muss ich in der C-Datei codieren


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);
}

dann von wo aus wird dieses printf es ausdrucken?
In Logcate verstehe ich es nicht?


Wie kann ich jede NDK-Anwendung debuggen, indem ich Protokollmeldungen einfüge?


Antworten:


Verwenden Sie __android_log_print() stattdessen. Sie müssen den Header <android/log.h> einfügen


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


Sie können auch Formatbezeichner wie printf -

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

Stellen Sie sicher, dass Sie auch mit der Protokollierungsbibliothek in Ihrer Android.mk-Datei verknüpfen:


  LOCAL_LDLIBS := -llog

Ohh.. vergessen.. Die Ausgabe wird in Logcat angezeigt mit Tag LOG_TAG


Einfacher Ansatz


Fügen Sie Ihrer allgemeinen Header-Datei die folgenden Zeilen hinzu.


#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

Rufen Sie jetzt einfach LOGD("Hello world") or LOGE("Number = %d", any_int) an wie printf in c .


Vergessen Sie nicht, die gemeinsame Header-Datei einzufügen.


Entfernen Sie die Protokollierung


Wenn Sie LOGD(...) definieren leer, alle Logs sind weg. Kommentiere einfach nach LOGD(...) .


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