若需要添加ndk對log的支持烟逊,只需要通過以下2步即可實(shí)現(xiàn)衷旅。
1.1 修改Android.mk
在Android.mk中添加如下內(nèi)容:LOCAL_LDLIBS:=-llog
1.2 在.c或.cpp文件中引用log頭文件
添加如下內(nèi)容:// 引入log頭文件#include <android/log.h>// log標(biāo)簽#define TAG "這里填寫日志的TAG"
// 定義debug信息#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, TAG, VA_ARGS)// 定義info信息#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG,VA_ARGS)
// 定義error信息#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG,VA_ARGS)
ANDROID_LOG_INFO:是日志級別;TAG:是要過濾的標(biāo)簽课锌,可以在LogCat視圖中過濾厨内。VA_ARGS:是實(shí)際的日志內(nèi)容。完成上面2步之后渺贤,我們就可以在.c/cpp文件中添加LOGI雏胃、LOGD、LOGE去打印信息志鞍!使用LOGI瞭亮、LOGD、LOGE的方法和使用printf一樣
1.3日志類型1)Log.v 的調(diào)試顏色為黑色的固棚,任何消息都會輸出统翩,這里的v代表verbose啰嗦的意思,平時(shí)使用就是Log.v(,);2)Log.d的輸出顏色是藍(lán)色的此洲,僅輸出debug調(diào)試的意思厂汗,但他會輸出上層的信息,過濾起來可以通過DDMS的Logcat標(biāo)簽來選擇3)Log.i的輸出為綠色呜师,一般提示性的消息information娶桦,它不會輸出Log.v和Log.d的信息,但會顯示i、w和e的信息4)Log.w的意思為橙色衷畦,可以看作為warning警告氮双,一般需要我們注意優(yōu)化Android代碼,同時(shí)選擇它后還會輸出Log.e的信息霎匈。5)Log.e為紅色戴差,可以想到error錯誤,這里僅顯示紅色的錯誤信息铛嘱,這些錯誤就需要我們認(rèn)真的分析暖释,查看棧的信息了。
如:
LOGI("user info----name:%s, age:%d, sex:%s.", "xxx", 18, "男");
執(zhí)行上句代碼可以再logcat中打印出相應(yīng)日志墨吓。
注意:log打印的方法中不能傳入jstring球匕,必須將jstring轉(zhuǎn)為c中的字符數(shù)組在傳入到方法里面打印,否則會報(bào)錯帖烘。
修改完之后Android.mk如下
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := TestNdk
LOCAL_SRC_FILES := com_example_testndkeclipse_JniClient.c
include $(BUILD_SHARED_LIBRARY)
LOCAL_LDLIBS += -llog
但是卻報(bào)錯
./obj/local/arm64-v8a/objs/TestNdk/com_example_testndkeclipse_JniClient.o: In function `Java_com_example_testndkeclipse_JniClient_AddStr':
F:\git_project_work_space\TestNdkEclipse/jni/com_example_testndkeclipse_JniClient.c:33: undefined reference to `__android_log_print'
clang++.exe: error: linker command failed with exit code 1 (use -v to see invocation)
make: *** [obj/local/arm64-v8a/libTestNdk.so] Error 1
這是因?yàn)?/p>
LOCAL_LDLIBS += -llog
添加的位置不對,改成如下即可
代碼已上傳至Github