NDK(Native Development Kit),是用于在 Android 應用中嵌套本地代碼的工具集,現在 Android 開發最常用的工具就是 Android Studio 了,筆者也是剛剛接觸 NDK 開發,用了一天的時間,踩了很多坑,最終跑通了自己的第一個 NDK 程式,話不多說,現在開始。
第一步:給 Android Studio 配置 NDK:
選擇 SDK Manager
選擇 SDK Tools
勾選 NDK 和一個 LLDB 版本,然後點選 Apply
接下來等待下載下傳安裝即可,下載下傳完成後,打開 File -- Project Structure -- SDK Location
然後選擇 Android NDK location,點選 Select default NDK
然後點選 OK,就配置好了,然後開始寫程式了
從第二步開始就是相當于屬于 JNI(Java Native Interface | Java 本地接口) 開發的基礎流程,因為 NDK 是基于 JNI 的。
第二步:建立一個 JNITEST.java 的一個類:
public class JNITest {
//建立一個 native 方法
public native static String get();
}
注意:如果你建立的 get() 方法是紅色的,并且有這樣的提示:Cannot resolve corresponding JNI function Java_com_example_akon_jnitest_JNITest_get more..
解決辦法:File -- Settings -- Plugins
搜尋 NDK,然後将 Android NDK Support 後面的勾去掉,點選 OK,然後 Restart
當然,如果你沒有這種情況就不用管。
第三步:建立 C 語言檔案,建立 so 庫
點選 Make Project,生成 JNITest.class 檔案
使用 Project 方式檢視目前項目,在目前目錄下可以看到你的 JNITest.class 檔案
打開 Android Studio 的 Terminal 到 移動到 app/src/main 目錄下
使用 javah -d jni -classpath F:\workSpace\Android\JNITest\app\build\intermediates\classes\debug com.example.akon.jnitest.JNITest 指令建立 .h 的頭檔案
javah:生成頭檔案
-d jni:目前目錄下建立一個 jni 檔案夾
-classpath .../debug 指定要生成頭檔案的位元組碼檔案目錄,即我們剛剛的 JNITest.class 的目錄
com.example.akon.jnitest.JNITest 是 JNITest 檔案的包名加上位元組碼檔案的名稱
注意:這個 debug 檔案目錄可能太長,輸入麻煩,我們可以找到 debug 檔案夾,右鍵 copy path,複制檔案目錄即可
現在我們可以看到 app/src/main 目錄下有一個 jni 檔案夾,裡面有一個 com_example_akon_jnitest_JNITest.h 的頭檔案,就是我們生成的頭檔案,頭檔案命名也是按照包名加位元組碼名的規範,以下劃線連接配接。
然後在 jni 目錄下建立一個 c/c++ resource 檔案 test.c,要選擇 c 為字尾:
#include<jni.h>
#include<stdio.h>
//導入我們建立的頭檔案
#include "com_example_akon_jnitest_JNITest.h"
JNIEXPORT jstring JNICALL Java_com_example_akon_jnitest_JNITest_get
(JNIEnv *env, jclass jclass){
//傳回一個字元串
return (*env)->NewStringUTF(env,"This is my first NDK Application");
}
下面的這個方法使我們從頭檔案中複制過來的
然後修改了參數,給了傳回值。
然後我們在 jni 目錄下建立兩個 .mk 檔案:
一個 Android.mk:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := JNITest
LOCAL_SRC_FILES := test.c
include $(BUILD_SHARED_LIBRARY)
一個是 Application.mk:
APP_ABI := all
然後我們需要生成 so 庫:
打開 Terminal,到 app/src/main/jni 目錄下,使用 ndk-build 指令生成 so 庫:
接着打開 app/src/main/libs 就可以看見我們生成的 so 庫了。
為了防止 so 庫相容錯誤,在 gradle.properties 最後一行添加:
android.useDeprecatedNdk=true
為了讓項目能夠找到我們的 so 庫,在 build.gradle 檔案夾的 android 下添加:
sourceSets {
main() {
jniLibs.srcDirs = ['src/main/libs']
jni.srcDirs = [] //屏蔽掉預設的jni編譯生成過程
}
}
然後我們在 JNITest.java 中動态導入 so 庫,不需要寫 libJNITest,隻用寫 JNITest:
package com.example.akon.jnitest;
public class JNITest {
// 動态導入 so 庫
static {
System.loadLibrary("JNITest");
}
//建立一個 native 方法
public native static String get();
}
然後我們在 MainActivity 中列印 JNITest 的 get() 方法擷取到的 String 值:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//列印資訊
Log.e("Message",JNITest.get());
}
}
然後運作,檢視日志,搜尋 Message:
然後我們就檢視到了我們擷取的 String 了,“This is my first NDK Application”,就是我們在 C 語言檔案中所傳回的字元串。
好了,第一個 NDK 程式就寫完了。
---------------------
版權聲明:本文為CSDN部落客「Young_Time」的原創文章,遵循CC 4.0 by-sa版權協定,轉載請附上原文出處連結及本聲明。
原文連結:https://blog.csdn.net/young_time/article/details/80346631