1、安裝
下載NDK包後,放到與SDK同級的目錄下,並且配置好環境變量,配好後,在終端輸入ndk-build命令測試,出現如下情況,則代表安裝成功
Android NDK: Could not find application project directory !
Android NDK: Please define the NDK_PROJECT_PATH variable to point to it.
/home/braincol/workspace/android/android-ndk-r5/build/core/build-local.mk:85: *** Android NDK: Aborting . Stop.
2、工程與代碼
a、新建android工程,編寫java代碼,寫好需要的本地方法,以及加載的c文件名字
b、根據寫好的java代碼,生成.h的c文件,其中生成.h文件的步驟如下:
1、進入該項目的目錄下
braincol@ubuntu:~$ cd workspace/android/NDK/hello-jni/
2、ls查看工程文件
braincol@ubuntu:~/workspace/android/NDK/hello-jni$ ls
AndroidManifest.xml assets bin default.properties gen res src
3、在工程目錄下建立一個jni文件夾:
braincol@ubuntu:~/workspace/android/NDK/hello-jni$ mkdir jni
braincol@ubuntu:~/workspace/android/NDK/hello-jni$ ls
AndroidManifest.xml assets bin default.properties gen jni res src
4、執行如下語句就可以生成相應的.h文件了:
braincol@ubuntu:~/workspace/android/NDK/hello-jni$ javah -classpath bin -d jni com.example.hellojni.HelloJni
c、根據b中生成好的.h文件來編寫相應的.c文件,根據自己的需要實現.h文件中的方法
d、編寫Android.mk文件,其格式爲如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := hello-jni //編譯的目標對象,系統將會生成 'libhello-jni.so'文件,供java文件調用
LOCAL_SRC_FILES := hello-jni.c //編譯的源文件,系統將根據該文件來生成目標對象
include $(BUILD_SHARED_LIBRARY)
e、生成.so共享庫文件,在終端進入到該項目的目錄下,輸入ndk-build命令,即可在lib目錄下生成.so文件,運行該項目,即可。
3、調試語句輸出
在 NDK 中, printf() 沒法輸出,所以我們需要藉助 log 庫來將我們 c 代碼庫中需要輸出的內容,通過 java 控制檯輸出。調用函數 __android_log_print(), 就可以在 Eclipse 中,查看 LogCat 來查看相關的輸出信息了。
於是在c文件的編寫中,需要引入android/log.h文件:
#include <android/log.h>
同時聲明打印方法:
#define __android_log_print(......);例如:
#include <string.h>
#include <stdio.h>
#include <jni.h>
#include <android/log.h>
#define LOG_TAG "MYJNI"
#define LOGI(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
static char s_string[] = "My god, I did it!";
jstring
Java_com_jpf_myjni_MyJNI_stringFromJNI( JNIEnv* env,jobject thiz )
{
LOGI("MyJNI is called!");
return (*env)->NewStringUTF(env, s_string);
}
因爲打印是鏈接的log庫,所以在Android.mk文件中加上如下一句:
LOCAL_LDLIBS += -llog
重新ndk-build,運行項目,可以在logcat中發現我們在c文件中加的打印語句。
參考:
http://www.cnblogs.com/hibraincol/archive/2011/05/30/2063847.html
http://blog.csdn.net/xuxinyl/article/details/6409030