在 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 4 4 种全架构的动态库 , 系统会将这四个动态库都打包到 APK 安装包中 ;
注意全架构动态库的 APK 大小是 7.7 M B \rm 7.7 MB 7.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 4 4 个 CPU 指令集架构的 APK 包有 7.7 M B \rm 7.7 MB 7.7MB , 只支持 “armeabi-v7a” 指令集架构的 APK 只有 5.9 M B \rm 5.9 MB 5.9MB , 优化效果比较可观 ;
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
下载地址 :