Android JNI和NDK學習(04)--NDK調試方法

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    "hello_load"
// 定義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__)
複製代碼

完成上面2步之後,我們就可以在.c/cpp文件中添加LOGI、LOGD、LOGE去打印信息!使用LOGI、LOGD、LOGE的方法和使用printf一樣,如LOGD("%s\n", __func__); 作用是輸出函數名。

 

 

2 ndk中log實例

下面通過實例增加log信息的方法。在“Android JNI和NDK學習(03)--動態方式實現JNI”的基礎上添加log信息。

(01) 修改ndk_load.c

修改後的ndk_load.c的內容如下(紅色部分爲 “與log相關的內容”):

複製代碼
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <jni.h>
#include <assert.h>


// 獲取數組的大小
# define NELEM(x) ((int) (sizeof(x) / sizeof((x)[0])))
// 指定要註冊的類,對應完整的java類名
#define JNIREG_CLASS "com/skywang/ndk/NdkLoad"


// 引入log頭文件
#include <android/log.h>  

// log標籤
#define  TAG    "hello_load"
// 定義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__)

// 返回字符串"hello load jni"
JNIEXPORT jstring JNICALL native_hello(JNIEnv *env, jclass clazz)
{
    LOGI("%s info\n", __func__);
    LOGD("%s debug\n", __func__);
    LOGE("%s error\n", __func__);
    return (*env)->NewStringUTF(env, "hello load jni.");
}

// Java和JNI函數的綁定表
static JNINativeMethod method_table[] = {
    { "HelloLoad", "()Ljava/lang/String;", (void*)native_hello },//綁定
};

// 註冊native方法到java中
static int registerNativeMethods(JNIEnv* env, const char* className,
        JNINativeMethod* gMethods, int numMethods)
{
    jclass clazz;
    clazz = (*env)->FindClass(env, className);
    if (clazz == NULL) {
        return JNI_FALSE;
    }
    if ((*env)->RegisterNatives(env, clazz, gMethods, numMethods) < 0) {
        return JNI_FALSE;
    }

    return JNI_TRUE;
}

int register_ndk_load(JNIEnv *env)
{
    // 調用註冊方法
    return registerNativeMethods(env, JNIREG_CLASS,
            method_table, NELEM(method_table));
}

JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved)
{
    JNIEnv* env = NULL;
    jint result = -1; 

    if ((*vm)->GetEnv(vm, (void**) &env, JNI_VERSION_1_4) != JNI_OK) {
        return result;
    }   

    register_ndk_load(env);

    // 返回jni的版本
    return JNI_VERSION_1_4;
}
複製代碼

(02) 修改Android.mk

修改後的Android.mk內容如下(紅色部分爲 “與log相關的內容”):

複製代碼
LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE    := ndk_load
LOCAL_SRC_FILES := ndk_load.c
# 添加對log庫的支持
LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog
#  注:若生成static的.a,只需添加 LOCAL_LDLIBS:=-llog 

include $(BUILD_SHARED_LIBRARY)

LOCAL_PATH := $(call my-dir)
複製代碼

(03) 重新生成.so文件,然後執行。

執行時,通過查看logcat信息,即可發現新增的log信息。如下圖:


點擊下載:http://files.cnblogs.com/skywang12345/NdkLoad_with_log_20130522.zip

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章