一、mk文件的結(jié)構(gòu)骨架
這里的骨架,就是指我們一般需要寫(xiě)的幾個(gè)重要的語(yǔ)句和模塊。還是采用Hello Jni的mk文件:
1 |
LOCAL_PATH := $(call my- dir ) |
[!--empirenews.page--]
3 |
LOCAL_MODULE := HelloJni |
[!--empirenews.page--]
4 |
LOCAL_SRC_FILES := HelloJni.c |
5 |
include $(BUILD_SHARED_LIBRARY) |
[!--empirenews.page--]
簡(jiǎn)單的5句話(huà)。
1. LOCAL_PATH := $(call my-dir) 。
一個(gè) Android.mk 文件 首先必須定義好 LOCAL_PATH 變量。它用于在開(kāi)發(fā)樹(shù)中查找源文件。在這個(gè)例子中,宏函數(shù)’my-dir’, 由編譯系統(tǒng)提供,用于返回當(dāng)前路徑(即包含 Android.mk 文件的目錄)。
2. include $(CLEAR_VARS)。
CLEAR_VARS 由編譯系統(tǒng)提供,指定讓 GNU MAKEFILE 為你清除許多 LOCAL_XXX 變量(例如 LOCAL_MODULE, LOCAL_SRC_FILES, LOCAL_STATIC_LIBRARIES, 等等 ...), 除 LOCAL_PATH 。這是必要的,因?yàn)樗械木幾g控制文件都在同一個(gè) GNU MAKE 執(zhí)行環(huán)境中,所有的變量都是全局的。
3. LOCAL_MODULE := HelloJni。
LOCAL_MODULE變量必須定義,以標(biāo)識(shí)你在Android.mk文件中描述的每個(gè)模塊。名稱(chēng)必須是唯一的,而且不包含任何空格。注意編譯系統(tǒng)會(huì)自動(dòng)產(chǎn)生合適的前綴和后綴,換句話(huà)說(shuō),一個(gè)被命名為‘HcSyncml‘的共享庫(kù)模塊,將會(huì)生成‘libHelloJni.so‘文件。
4. LOCAL_SRC_FILES := HelloJni.c
LOCAL_SRC_FILES中加入源文件路徑(需要編譯的文件),多個(gè)文件用 ‘ ’ 隔開(kāi),如果要換行,用‘’+ 回車(chē)換行。
5. include $(BUILD_SHARED_LIBRARY)
表示生成一個(gè)共享庫(kù),其他的還有BUILD_STATIC_LIBRARY(這個(gè)表示生成一個(gè)靜態(tài)庫(kù))。
二、在Jni中打日志LOG
在Jni中打日志(還是以Hello Jni為例),
1. 需要mk文件中再加入一條語(yǔ)句:
[!--empirenews.page--]
2.HelloJni.c文件中,加入頭文件和函數(shù)聲明。最終文件如下:
02 |
#include <android/log.h> |
[!--empirenews.page--]
[!--empirenews.page--]
05 |
#define LOG_TAG "HelloJni" |
06 |
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__) |
[!--empirenews.page--]
07 |
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__) |
[!--empirenews.page--]
09 |
jstring Java_com_example_hellojni_MainActivity_getHelloJniString |
10 |
(JNIEnv * env, jobject clazz) |
[!--empirenews.page--]
12 |
LOGI( "call from jni!" ); |
[!--empirenews.page--]
13 |
return (*env)->NewStringUTF(env, "Hello Jni!" ); |
[!--empirenews.page--]
除了ANDROID_LOG_INFO這個(gè)日志級(jí)別,還有如下的:
[!--empirenews.page--]
[!--empirenews.page--]
[!--empirenews.page--]
[!--empirenews.page--]
[!--empirenews.page--]
3.編譯so文件,運(yùn)行程序吧!奇跡出現(xiàn)啦!
4.LOGI除了直接輸出字符串,也可以用占位符的方式顯示。例如
LOGI(%s,"call from jni!");