1. 程式人生 > >android studio 中jni底層日誌的打印

android studio 中jni底層日誌的打印

添加 註意 erro ldl end 1.0 dto 字符 ati

1 添加ndk對log支持
若需要添加ndk對log的支持,只需要通過以下2步即可實現。


1.1 修改Android.mk
如生成的庫文件是“.so文件”,則在Android.mk中添加如下內容:
LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog
如生成的庫文件是“.a文件”,則在Android.mk中添加如下內容:
LOCAL_LDLIBS:=-llog

1.2 在.c或.cpp文件中引用log頭文件
添加如下內容:
// 引入log頭文件
#include <android/log.h>
// log標簽
#define TAG "這裏填寫日誌的TAG"
// 定義info信息
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG,__VA_ARGS__)
// 定義debug信息
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, TAG, __VA_ARGS__)
// 定義error信息
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG,__VA_ARGS__)

ANDROID_LOG_INFO:是日誌級別;
TAG:是要過濾的標簽,可以在LogCat視圖中過濾。
__VA_ARGS__:是實際的日誌內容。
完成上面2步之後,我們就可以在.c/cpp文件中添加LOGI、LOGD、LOGE去打印信息!使用LOGI、LOGD、LOGE的方法和使用printf一樣

1.3日誌類型
1)Log.v 的調試顏色為黑色的,任何消息都會輸出,這裏的v代表verbose啰嗦的意思,平時使用就是Log.v(,);
2)Log.d的輸出顏色是藍色的,僅輸出debug調試的意思,但他會輸出上層的信息,過濾起來可以通過DDMS的Logcat標簽來選擇
3)Log.i的輸出為綠色,一般提示性的消息information,它不會輸出Log.v和Log.d的信息,但會顯示i、w和e的信息
4)Log.w的意思為橙色,可以看作為warning警告,一般需要我們註意優化Android代碼,同時選擇它後還會輸出Log.e的信息。
5)Log.e為紅色,可以想到error錯誤,這裏僅顯示紅色的錯誤信息,這些錯誤就需要我們認真的分析,查看棧的信息了。

如:

LOGI("user info----name:%s, age:%d, sex:%s.", "xxx", 18, "男");

執行上句代碼可以再logcat中打印出相應日誌。

註意:log打印的方法中不能傳入jstring,必須將jstring轉為c中的字符數組在傳入到方法裏面打印,否則會報錯。

特別需要強調的是在android studio 通過上層配置之後,運行的時候會報錯:

提示

技術分享

如何解決了,在app的gradle配置文件中設置:

ldLibs "log"
apply plugin: com.android.application

android {
    compileSdkVersion 
25 buildToolsVersion "23.0.3" defaultConfig { applicationId "im.weiyuan.com.jni" minSdkVersion 16 targetSdkVersion 25 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" ndk{ moduleName "hello" //設置庫(so)文件名稱 abiFilters "armeabi", "armeabi-v7a", "x86" ldLibs "log" } } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile(proguard-android.txt), proguard-rules.pro } } } dependencies { compile fileTree(dir: libs, include: [*.jar]) androidTestCompile(com.android.support.test.espresso:espresso-core:2.2.2, { exclude group: com.android.support, module: support-annotations }) compile com.android.support:appcompat-v7:25.2.0 testCompile junit:junit:4.12 }

android studio 中jni底層日誌的打印