下面實現本地代碼,再用ndk-build編譯產生.so庫檔案。由於編譯時間要用到make和gcc,這裡很多人是通過安裝cygwin,搭建一個linux環境編譯。我是直接用Android NDK裡ndk-build工具編譯,沒有安裝cygwin,也能編譯。
一、編寫本地代碼fib.c
首先在過程fiblib下建立一個目錄jni,將上一篇產生的jni標頭檔添加到這個目錄,接著在源碼目錄下建立檔案fib.c:
檔案jni/fib.c:
?#include "com_example_fiblib_FibLib.h" //遞迴的斐波那契演算法 long fibN(long n){ if(n<0) return 0; if(n==1) return 1; return fibN(n-1)+fibN(n-2); } //迭代的斐波那契演算法 long fibNI(long n){ long previous = -1; long result = 1; long i = 0; int sum = 0; for (i=0;i<=n;i++){ sum = result + previous; previous = result; result = sum; } return result; } //與標頭檔產生的JNI方法的簽名一致,否則運行時無法調用到本地代碼 JNIEXPORT jlong JNICALL Java_com_example_fiblib_FibLib_fibN (JNIEnv *env, jclass obj, jint n){ return fibN(n); } JNIEXPORT jlong JNICALL Java_com_example_fiblib_FibLib_fibNI (JNIEnv *env, jclass obj, jint n){ return fibNI(n); } #include "com_example_fiblib_FibLib.h"//遞迴的斐波那契演算法long fibN(long n){ if(n<0) return 0; if(n==1) return 1; return fibN(n-1)+fibN(n-2);}//迭代的斐波那契演算法long fibNI(long n){ long previous = -1; long result = 1; long i = 0; int sum = 0; for (i=0;i<=n;i++){ sum = result + previous; previous = result; result = sum; } return result;}//與標頭檔產生的JNI方法的簽名一致,否則運行時無法調用到本地代碼JNIEXPORT jlong JNICALL Java_com_example_fiblib_FibLib_fibN (JNIEnv *env, jclass obj, jint n){ return fibN(n);}JNIEXPORT jlong JNICALL Java_com_example_fiblib_FibLib_fibNI (JNIEnv *env, jclass obj, jint n){ return fibNI(n);}
二、編寫Makefile·
建立本地庫之前,需要編寫Android.mk,描述編譯項目
檔案jni/Android.mk
LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := fib LOCAL_SRC_FILES := fib.c include $(BUILD_SHARED_LIBRARY) LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := fibLOCAL_SRC_FILES := fib.c
include $(BUILD_SHARED_LIBRARY)三、編譯構建共用庫
這裡需要在jni下執行ndk-build產生庫檔案,即在libs下產生共用庫libfib.so
右擊工程Refresh下,就看到產生了libfib.so