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) 1. 于是在网上搜罗了一番解决方案,基本都是说把 .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'
? ? ? ? }
? ? }
? ? ...
}
----------------------------------- ?著作权归作者所有:来自51CTO博客作者ZeroOne01的原创作品,请联系作者获取转载授权,否则将追究法律责任 集成科大讯飞语音合成Android SDK遇到的坑 https://blog.51cto.com/zero01/2622074
com.iflytek.cloud.a.c.c occur Error = 本地引擎错误.(错误码:20021)
|