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

次の 2 つのオプションがあります。

1) printf を __android_log_print に置き換えます。これは、コードの先頭で define を使用して簡単に実行できます。

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

もちろん、これには printf を含むすべてのソース コードを変更する必要があります。

2) stdout と stderr を Android logcat にリダイレクトします (ルート化されていないデバイスで動作するかどうかは不明です): http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd

于 2012-04-23T05:53:33.997 に答える
7

以下の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 に答える