Android學習筆記:NDK入門一些總結

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

 

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