文章目录
一、动态库打包配置
二、NDK 完整配置参考
三、参考资料
一、动态库打包配置
在 build.gradle 构建脚本中 , 配置 ndk 编译的动态库 CPU 架构类型 ;
在 " android / defaultConfig / ndk " 层级下 , 配置 abiFilters 选项 , 为其配置需要打包的 动态库 CPU 架构 ;
如果按照 abiFilters “armeabi-v7a”, “arm64-v8a”, “x86”, “x86_64” 配置 , 则打包时会将四种 CPU 架构的动态库都配置到 APK 中 ;
全指令集架构的动态库打包配置 :
android { defaultConfig { // II . NDK 配置 2 : 配置 AS 工程中的 C/C++ 源文件的编译 //配置 APK 打包 哪些动态库 // 示例 : 如在工程中集成了第三方库 , // 其提供了 "armeabi-v7a" , "arm64-v8a", "x86", "x86_64" 等指令集的动态库 // 那么为了控制打包后的应用大小, 可以选择性打包一些库 , 此处就是进行该配置 ndk{ // 打包生成的 APK 文件指挥包含 ARM 指令集的动态库 abiFilters "armeabi-v7a", "arm64-v8a", "x86", "x86_64" } } }
打包时 , 如果当前工程资源中 , 有 4 44 种全架构的动态库 , 系统会将这四个动态库都打包到 APK 安装包中 ;
注意全架构动态库的 APK 大小是 7.7 M B \rm 7.7 MB7.7MB ;
事实上 , 绝大部分应用都不需要配置全架构的动态库 , 市面上的 x86 手机几乎绝迹 , 另外 “arm64-v8a” 架构的 CPU 可以向下兼容 “armeabi-v7a” 架构的动态库 ;
因此 , 这里只提供 “armeabi-v7a” 架构的动态库即可 , 市面上大部分应用也是这么干的 ; ( 即使是微信也只支持 armeabi 这一个架构 )
注意 : 如果要在电脑上的 Android 模拟器上运行动态库 , 需要支持 “x86” 架构 , 大部分 PC 上的 Android 模拟器都是 x86 架构的 ;
只支持 “armeabi-v7a” 指令集架构的动态库打包配置 :
android { defaultConfig { // II . NDK 配置 2 : 配置 AS 工程中的 C/C++ 源文件的编译 //配置 APK 打包 哪些动态库 // 示例 : 如在工程中集成了第三方库 , // 其提供了 "armeabi-v7a" , "arm64-v8a", "x86", "x86_64" 等指令集的动态库 // 那么为了控制打包后的应用大小, 可以选择性打包一些库 , 此处就是进行该配置 ndk{ // 打包生成的 APK 文件指挥包含 ARM 指令集的动态库 abiFilters "armeabi-v7a"/*, "arm64-v8a", "x86", "x86_64"*/ } } }
配置完毕后 , 编译新的 APK 文件 ;
打包后的结果如下 , 支持 4 44 个 CPU 指令集架构的 APK 包有 7.7 M B \rm 7.7 MB7.7MB , 只支持 “armeabi-v7a” 指令集架构的 APK 只有 5.9 M B \rm 5.9 MB5.9MB , 优化效果比较可观 ;
二、NDK 完整配置参考
plugins { id 'com.android.application' id 'kotlin-android' } android { compileSdkVersion 30 buildToolsVersion "30.0.3" defaultConfig { applicationId "kim.hsl.a7_zip" minSdkVersion 18 targetSdkVersion 30 versionCode 1 versionName "1.0" testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" // I . NDK 配置 1 : 配置 AS 工程中的 C/C++ 源文件的编译 // defaultConfig 内部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件编译参数 // defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android1.mk 构建脚本的路径 externalNativeBuild { cmake { cppFlags "" //配置编译 C/C++ 源文件为哪几个 CPU 指令集的函数库 (arm , x86 等) abiFilters "armeabi-v7a", "arm64-v8a", "x86", "x86_64" } /*ndkBuild{ abiFilters "armeabi-v7a" *//*, "arm64-v8a", "x86", "x86_64"*//* }*/ } // II . NDK 配置 2 : 配置 AS 工程中的 C/C++ 源文件的编译 //配置 APK 打包 哪些动态库 // 示例 : 如在工程中集成了第三方库 , // 其提供了 "armeabi-v7a" , "arm64-v8a", "x86", "x86_64" 等指令集的动态库 // 那么为了控制打包后的应用大小, 可以选择性打包一些库 , 此处就是进行该配置 ndk{ // 打包生成的 APK 文件指挥包含 ARM 指令集的动态库 abiFilters "armeabi-v7a"/*, "arm64-v8a", "x86", "x86_64"*/ } } // III . NDK 配置 : 配置 AS 工程中的 C/C++ 源文件的编译构建脚本 // 配置 NDK 的编译脚本路径 // 编译脚本有两种 ① CMakeList.txt ② Android.mk // defaultConfig 内部的 externalNativeBuild 配置的是配置 AS 工程的 C/C++ 源文件编译参数 // defaultConfig 外部的 externalNativeBuild 配置的是 CMakeList.txt 或 Android1.mk 构建脚本的路径 externalNativeBuild { // 配置 CMake 构建脚本 CMakeLists.txt 脚本路径 cmake { path "src/main/cpp/CMakeLists.txt" //path "src/main/staticLibs/CMakeLists.txt" version "3.10.2" } // 配置 Android1.mk 构建脚本路径 /*ndkBuild{ //path "src/main/ndkBuild_Shared/Android.mk" path "src/main/ndkBuild_Static/Android.mk" }*/ } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' } } compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } kotlinOptions { jvmTarget = '1.8' } } dependencies { implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" implementation 'androidx.core:core-ktx:1.3.2' implementation 'androidx.appcompat:appcompat:1.2.0' implementation 'com.google.android.material:material:1.3.0' implementation 'androidx.constraintlayout:constraintlayout:2.0.4' testImplementation 'junit:junit:4.+' androidTestImplementation 'androidx.test.ext:junit:1.1.2' androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0' }
三、参考资料
博客资源 :
GitHub 项目源码 : https://github.com/han1202012/7-Zip
下载地址 :