如果我在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将从哪里打印它的消息?在日志中我不明白吗?
如何通过放置日志消息来调试任何 NDK 应用程序?
改用__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
现在只需像printf in c
一样称呼LOGD("Hello world") or LOGE("Number = %d", any_int)
.
不要忘记包含通用头文件。
删除日志记录
如果将LOGD(...)
定义为空,则所有日志都将消失。只是在LOGD(...)
后发表评论.
#define LOGD(...) // __android_log..... rest of the code
有两个选项:
1) 将 printf 替换为 __android_log_print。您可以使用代码开头的定义轻松完成此操作:
#define printf(...) __android_log_print(ANDROID_LOG_DEBUG, "TAG", __VA_ARGS__);
当然,这将需要更改所有具有 printf 的源代码。
2)将标准输出和标准删除到Android logcat(不确定这是否适用于无根设备):http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd
不需要root设备,http://developer.android.com/guide/developing/debugging/debugging-log.html#viewingStd,下面就可以很好地工作。
$ adb shell
$ su
$ stop
$ setprop log.redirect-stdio true
$ start
做!