这种问题通常出现在使用Native代码时。其中,Native代码是由C、C++或其他类似的语言编写而成的,然后将其编译成Android平台支持的共享库文件(.so)。在构建过程中,编译器会将代码打包成apk中的可执行文件。
如果出现“Module .so not loaded in apk, but is built”问题,通常会提示以下错误:
java.lang.UnsatisfiedLinkError: No implementation found for long xxxxx
其中,xxxxx是链接到所需共享库的本机函数的名称。这意味着应用程序需要该模块以便运行,但在apk中未加载该模块。
因此,我们需要在构建中包含这个.so文件,使其在运行时被加载。我们可以在app的build.gradle文件中增加以下配置:
android {
...
defaultConfig {
...
ndk {
//设置.ndk模块的路径
abiFilters 'armeabi-v7a','arm64-v8a','x86','x86_64','mips','mips64'
}
}
...
}
sourceSets {
main {
//设置.so文件的路径
jniLibs.srcDirs = ['src/main/libs']
}
}
在这个配置中,我们将ndk模块的路径和我们需要的so文件夹的路径都设置好了。接下来,通过在代码中声明所需的本地方法,而不是直接使用它们,就可以解决这个问题。例如:
public native long xxxxx();
然后,在调用此方法之前,需要将该共享库加载到应用程序中:
static {
System.loadLibrary("xxxxx");
}
通过这种方式,我们就可以将我们所需的so文件正确地打包到apk中,并在需要时将其加载。这样,应用程序就可以运行我们的Native代码了。