日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

【Android NDK 开发】Android Studio 的 NDK 配置 ( 源码编译配置 | 构建脚本配置 | 打包配置 | CMake 配置 | ndkBuild 配置 )

發(fā)布時間:2025/6/17 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Android NDK 开发】Android Studio 的 NDK 配置 ( 源码编译配置 | 构建脚本配置 | 打包配置 | CMake 配置 | ndkBuild 配置 ) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

        • I . 源碼編譯配置
        • II . 構建腳本配置
        • III . NDK 函數(shù)庫打包配置
        • IV . Java 與 C 代碼示例
        • V . CMake 配置 ( CMakeLists.txt )
        • VI . ndkBuild 配置 ( Android.mk )
        • VII . 博客相關資源下載



I . 源碼編譯配置



1 . 源碼編譯配置 :


① 配置位置 : Module 級別的 build.gradle 中進行配置 ;

② 主要作用 : 主要作用是配置本工程中的 C/C++ 源碼如何編譯成動態(tài)庫的 ;

③ 常用配置 : 一般配置將源碼編譯成哪幾個 CPU 的指令集 ;

目前只支持 armeabi-v7a , arm64-v8a , x86 , x86-64 四種 CPU 指令集架構 ;


2 . 配置層級 : 在 android 下 defaultConfig 中配置的 externalNativeBuild 是配置 AS 中的 C/C++ 源碼編譯內容的 ;


注意區(qū)分配置 : externalNativeBuild 有兩種類型的配置 , 一種在 defaultConfig 內部 , 一種在 defaultConfig 外部 ;


① defaultConfig 內部的 externalNativeBuild : 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)

② defaultConfig 外部的 externalNativeBuild : 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑


2 . 配置腳本示例 ( 省略無關內容 ) :

apply plugin: 'com.android.application'android {...defaultConfig {.../*關于 CPU 指令集NDK 17 以上只支持 armeabi-v7a, arm64-v8a, x86, x86-64 四種 CPU 架構*/// 配置 AS 工程中的 C/C++ 源文件的編譯// defaultConfig 內部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑externalNativeBuild {cmake {cppFlags ""//配置編譯 C/C++ 源文件為哪幾個 CPU 指令集的函數(shù)庫 (arm , x86 等)abiFilters "armeabi-v7a" , "arm64-v8a", "x86", "x86_64"}}...}... }

II . 構建腳本配置



1 . 構建腳本配置 :


① 配置位置 : Module 級別的 build.gradle 中進行配置 ;

② 主要作用 : 主要作用是配置本工程中的 C/C++ 源碼的構建腳本 ;

③ 常用配置 : 配置 cmake 或 ndkBuild 兩種編譯腳本中的一種 ( 只能二選一 ) ;


2 . cmake 配置 : 配置使用 CMake 編譯 C/C++ 時的構建腳本 CMakeList.txt 路徑 ;


① cmake 簡介 : 使用 CMake 進行構建 , 構建腳本是 CMakeList.txt , 是 Android Studio 中新引入的 NDK 本地代碼構建方式 ;

② 路徑設置 : 路徑的起點就是 build.gradle 文件所在的目錄 , 即 app 目錄 ;

② 配置示例 :

externalNativeBuild {cmake {path "src/main/cpp/CMakeLists.txt"version "3.10.2"}

3 . ndkBuild 配置 : 配置使用 ndkBuild 編譯 C/C++ 時的構建腳本 Android.mk 路徑 ;


① ndkBuild 簡介 : 使用 ndkBuild 進行構建 , 構建腳本是 Android.mk , 是從 Eclipse + ADT 環(huán)境遺留下來的配置 NDK 編譯方案 , 逐步被 CMake 替代 ;

② 路徑設置 : 路徑的起點就是 build.gradle 文件所在的目錄 , 即 app 目錄 ;

② 配置示例 :

externalNativeBuild {ndkBuild{path "src/main/cpp/Android.mk"}

3 . 配置層級 : 在 android 與 defaultConfig 平級的 externalNativeBuild 是配置 AS 中的 C/C++ 源碼編譯構建腳本的 ;


注意區(qū)分配置 : externalNativeBuild 有兩種類型的配置 , 一種在 defaultConfig 內部 , 一種在 defaultConfig 外部與之平級的配置 ;


① defaultConfig 內部的 externalNativeBuild : 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)

② defaultConfig 外部的 externalNativeBuild : 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑


4 . 配置腳本示例 ( 省略無關內容 ) :

apply plugin: 'com.android.application'android {...defaultConfig {...}// 配置 NDK 的編譯腳本路徑// 編譯腳本有兩種 ① CMakeList.txt ② Android.mk// defaultConfig 內部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑externalNativeBuild {// 配置 CMake 構建腳本 CMakeLists.txt 腳本路徑// 使用該配置時 , 將 ndkBuild 配置注釋掉cmake {path "src/main/cpp/CMakeLists.txt"version "3.10.2"}// 配置 Android.mk 構建腳本路徑// 使用該配置時 , 將 cmake 配置注釋掉/*ndkBuild{path "src/main/cpp/Android.mk"}*/}... } ...

III . NDK 函數(shù)庫打包配置



1 . 構建腳本配置 :


① 配置位置 : Module 級別的 build.gradle 中進行配置 ;

② 主要作用 : 主要作用是配置 APK 打包動態(tài)庫的相關參數(shù) ; 如在工程中編譯的函數(shù)庫 , 其提供了 arm, x86, mips 等指令集的動態(tài)庫 , 那么為了控制打包后的應用大小, 可以選擇性打包一些庫 , 此處就是進行該配置 ;

③ 常用配置 : 配置 cmake 或 ndkBuild 兩種編譯腳本中的一種 ( 只能二選一 ) ;


2 . 配置腳本示例 ( 省略無關內容 ) :

apply plugin: 'com.android.application'android {...defaultConfig {.../*關于 CPU 指令集NDK 17 以上只支持 armeabi-v7a, arm64-v8a, x86, x86-64 四種 CPU 架構*///配置 APK 打包 哪些動態(tài)庫// 示例 : 如在工程中編譯的函數(shù)庫 , 其提供了 arm, x86, mips 等指令集的動態(tài)庫// 那么為了控制打包后的應用大小, 可以選擇性打包一些庫 , 此處就是進行該配置ndk{// 打包生成的 APK 文件指揮包含 ARM 指令集的動態(tài)庫abiFilters "armeabi-v7a" , "arm64-v8a", "x86", "x86_64"}...}... }

IV . Java 與 C 代碼示例



1 . Java 代碼 :

package kim.hsl.compile;import androidx.appcompat.app.AppCompatActivity;import android.os.Bundle; import android.widget.TextView;public class MainActivity extends AppCompatActivity {static {//此處只能加載動態(tài)庫 , 不能加載靜態(tài)庫System.loadLibrary("native-lib");}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);TextView tv = findViewById(R.id.sample_text);tv.setText(stringFromJNI());}public native String stringFromJNI();}

2 . C 代碼 :

#include <jni.h> #include <android/log.h>JNIEXPORT jstring JNICALL Java_kim_hsl_compile_MainActivity_stringFromJNI(JNIEnv *env,jobject obj) {__android_log_print(ANDROID_LOG_INFO, "JNI_TAG", "Hello from C");return (*env)->NewStringUTF(env, "Hello from C"); }

V . CMake 配置 ( CMakeLists.txt )



1 . CMakeLists.txt 配置示例 :

# 聲明 CMake 版本 cmake_minimum_required(VERSION 3.4.1)# 添加庫 add_library( # Sets the name of the library.native-lib# Sets the library as a shared library.SHARED# Provides a relative path to your source file(s).native-lib.c)# 到預設的目錄查找 log 庫 , 將找到的路徑賦值給 log-lib # 這個路徑是 NDK 的 ndk-bundle\platforms\android-29\arch-arm\usr\lib\liblog.so # 不同的 Android 版本號 和 CPU 架構 需要到對應的目錄中查找 , 此處是 29 版本 32 位 ARM 架構的日志庫 find_library(log-liblog)# 鏈接庫 target_link_libraries(native-lib${log-lib})

2 . 對應的 build.gradle 中的 NDK 配置 :

apply plugin: 'com.android.application'android {.../*關于 CPU 指令集NDK 17 以上只支持 armeabi-v7a, arm64-v8a, x86, x86-64 四種 CPU 指令集架構*/// 配置 AS 工程中的 C/C++ 源文件的編譯// defaultConfig 內部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑externalNativeBuild {cmake {cppFlags ""//配置編譯 C/C++ 源文件為哪幾個 CPU 指令集的函數(shù)庫 (arm , x86 等)abiFilters "armeabi-v7a" , "arm64-v8a", "x86", "x86_64"}}//配置 APK 打包 哪些動態(tài)庫// 示例 : 如在工程中編譯的函數(shù)庫 , 其提供了 arm, x86, mips 等指令集的動態(tài)庫// 那么為了控制打包后的應用大小, 可以選擇性打包一些庫 , 此處就是進行該配置ndk{// 打包生成的 APK 文件指揮包含 ARM 指令集的動態(tài)庫abiFilters "armeabi-v7a" , "arm64-v8a", "x86", "x86_64"}}// 配置 NDK 的編譯腳本路徑// 編譯腳本有兩種 ① CMakeList.txt ② Android.mk// defaultConfig 內部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑externalNativeBuild {// 配置 CMake 構建腳本 CMakeLists.txt 腳本路徑// 使用該配置時 , 將 ndkBuild 配置注釋掉cmake {path "src/main/cpp/CMakeLists.txt"version "3.10.2"}// 配置 Android.mk 構建腳本路徑// 使用該配置時 , 將 cmake 配置注釋掉/*ndkBuild{path "src/main/cpp/Android.mk"}*/}... } ...

VI . ndkBuild 配置 ( Android.mk )



1 . Android.mk 配置示例 :

# my-dir 是 NDK 內置的函數(shù) , 獲取當前的目錄路徑 # 在該案例中就是 Android.mk 文件所在的目錄的絕對路徑 , 工程根目錄/app/src/main/cpp # 將該目錄賦值給 LOCAL_PATH 變量 # 所有的 Android.mk 的第一行配置都是該語句LOCAL_PATH := $(call my-dir)# 打印 LOCAL_PATH 值 # Build 打印內容 : LOCAL_PATH : Y:/002_WorkSpace/001_AS/005_NDK_Compile/app/src/main/cpp # 編譯 APK 時會在 Build 中打印$(info LOCAL_PATH : $(LOCAL_PATH))# 配置新的模塊之前都要先清除 LOCAL_XXX 變量 # LOCAL_PATH 變量會保留include $(CLEAR_VARS)# 配置動態(tài)庫名稱 # 動態(tài)庫命名規(guī)則 : 在 LOCAL_MODULE 基礎上 , 添加 lib 前綴 和 .so 后綴 # 生成動態(tài)庫名稱 : libnative-lib.soLOCAL_MODULE := native-lib# 編譯的源文件LOCAL_SRC_FILES := native-lib.c# 配置構建的目標是動態(tài)庫include $(BUILD_SHARED_LIBRARY)

2 . 對應的 build.gradle 中的 NDK 配置 :

apply plugin: 'com.android.application'android {.../*關于 CPU 指令集NDK 17 以上只支持 armeabi-v7a, arm64-v8a, x86, x86-64 四種 CPU 指令集架構*/// 配置 AS 工程中的 C/C++ 源文件的編譯// defaultConfig 內部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑externalNativeBuild {cmake {cppFlags ""//配置編譯 C/C++ 源文件為哪幾個 CPU 指令集的函數(shù)庫 (arm , x86 等)abiFilters "armeabi-v7a" , "arm64-v8a", "x86", "x86_64"}}//配置 APK 打包 哪些動態(tài)庫// 示例 : 如在工程中編譯的函數(shù)庫 , 其提供了 arm, x86, mips 等指令集的動態(tài)庫// 那么為了控制打包后的應用大小, 可以選擇性打包一些庫 , 此處就是進行該配置ndk{// 打包生成的 APK 文件指揮包含 ARM 指令集的動態(tài)庫abiFilters "armeabi-v7a" , "arm64-v8a", "x86", "x86_64"}}// 配置 NDK 的編譯腳本路徑// 編譯腳本有兩種 ① CMakeList.txt ② Android.mk// defaultConfig 內部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件編譯參數(shù)// defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android.mk 構建腳本的路徑externalNativeBuild {// 配置 CMake 構建腳本 CMakeLists.txt 腳本路徑// 使用該配置時 , 將 ndkBuild 配置注釋掉/*cmake {path "src/main/cpp/CMakeLists.txt"version "3.10.2"}*/// 配置 Android.mk 構建腳本路徑// 使用該配置時 , 將 cmake 配置注釋掉ndkBuild{path "src/main/cpp/Android.mk"}}... } ...

VII . 博客相關資源下載



CSDN 博客地址 : 【Android NDK 開發(fā)】Android Studio 的 NDK 配置 ( 源碼編譯配置 | 構建腳本配置 | 打包配置 | CMake 配置 | ndkBuild 配置 )

博客資源下載地址 : https://download.csdn.net/download/han1202012/12152060

示例代碼 GitHub 地址 : https://github.com/han1202012/005_NDK_Compile

總結

以上是生活随笔為你收集整理的【Android NDK 开发】Android Studio 的 NDK 配置 ( 源码编译配置 | 构建脚本配置 | 打包配置 | CMake 配置 | ndkBuild 配置 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。