loadLibrary msc error:java.lang.UnsatisfiedLinkError: dlopen failed: library "libmsc.so" not found
解决这个坑还花了挺长时间的(可能是因为太菜了),特此记录一下。
背景:为了实现个机器人语音播报的小功能,集成了科大讯飞的语音合成Android SDK。
问题:按照官方文档的描述进行集成后,结果一启动就报如下错误:
E/MscSpeechLog: loadLibrary msc error:java.lang.UnsatisfiedLinkError: dlopen failed: library "libmsc.so" not found
E/MscSpeechLog: init failed
W/System.err: 组件未安装.(错误码:21002)
at com.iflytek.cloud.SpeechUtility.<init>(SourceFile:201)
W/System.err: at com.iflytek.cloud.SpeechUtility.createUtility(SourceFile:140)
at com.zj.smartbutler.application.BaseApplication.onCreate(BaseApplication.kt:28)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1192)
W/System.err: at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6712)
at android.app.ActivityThread.access$1300(ActivityThread.java:237)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1913)
at android.os.Handler.dispatchMessage(Handler.java:106)
W/System.err: at android.os.Looper.loop(Looper.java:223)
at android.app.ActivityThread.main(ActivityThread.java:7656)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
这个问题会导致SDK初始化失败:
// 初始化Speech
SpeechUtility.createUtility(
this, "${SpeechConstant.APPID}=${Constants.VOICE_APP_ID}"
)
从而导致执行这句代码时报空指针异常:
mTts = SpeechSynthesizer.createSynthesizer(activity, mTtsInitListener)
于是在网上搜罗了一番解决方案,基本都是说把 .so
文件目录放到 src/main/jniLibs
下,或者放到app/libs
下,然后在 build.gradle
中配置 sourceSets
。然而,我都尝试了一遍并没有解决这个问题。
解决方式
找了半天原因,结果是因为我使用的模拟器是x86的,但科大讯飞的语音合成只支持arm,并且我在ndk中配置了x86。错误配置如下:
android {
...
defaultConfig {
...
ndk {
// 设置支持的SO库架构
abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a', 'x86_64', 'x86'
}
}
...
}
将x86相关的配置删除后,如下,再次启动就没问题了:
android {
...
defaultConfig {
...
ndk {
// 设置支持的SO库架构
abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a'
}
}
...
}