关于Java.lang.UnsatisfiedLinkError的错误解决办法

2024-08-28 01:18

本文主要是介绍关于Java.lang.UnsatisfiedLinkError的错误解决办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

把原本一直在魅蓝metal测试的android地面站换到S6 edge中运行就报java.lang.UnsatisfiedLinkError: No implementation found for void com.mmc.groundstation.activities.activity.GroundStationActivity.startVideoStream(java.lang.Object) (tried Java_com_mmc_groundstation_activities_activity_GroundStationActivity_startVideoStream and Java_com_mmc_groundstation_activities_activity_GroundStationActivity_startVideoStream__Ljava_lang_Object_2)


其实在Android开发中,我发现通常引用了一些第三方的sdk的so库之后,不同机型之间就会发生这样一个错误,
Java.lang.UnsatisfiedLinkError!
举个例子:
你原先的项目中只使用了A公司提供的so包,他只提供了armeabi这个架构的so包,后来项目需要又引用了B公司的提供的sdk,里面提供的so包还挺全的,arm64-v8a,armeabi-v7a,mips,mips64,x86等等,结果你就全放进去了, 后来发现突然某手机就出现了崩溃,然后一般都是因为这个问题
Java.lang.UnsatisfiedLinkError
所以呢,为了解决这个问题,也有人提出了解决办法:
这种情况一般是由于libinet.x.x.x so(x.x.x代表版本号,比如libinet.1.6.2)文件未加载成功导致的,解决方法有两种:  
方法一:  
首先确认libs目录下每个存放so文件的目录是否包含了libinet.x.x.x.so文件。  
比如armeabi和armeabi-v7a,但是armeabi-v7a中没有libinet.x.x.x.so,这是不允许的,请从armeabi中复制。  
比如x86_64没有libinet.x.x.x.so,请从我们提供的demo中对应的x86_64目录复制(不能从demo的armeabi目录复制,因为平台类型不一致,保证从demo中同名的目录复制文件)。  
方法二:  
仅仅保留armeabi和x86目录,删除其它多余的目录(比如arm64-v8a,x86_64等),同时确认armeabi和x86目录有libinet.x.x.x.so文件。  
注意,这里所说的仅仅保留armeabi和x86目录是指主工程和所有依赖工程都只能仅仅保留armeabi和x86目录,若主工程或者某一个依赖工程中包含了其他目录(例如x86_64),还是会存在问题的。  
如果用这种方法处理后没有解决该问题,请用解压软件解压apk,然后看一下lib目录下是否只有armeabi和x86目录,如果有armeabi和x86目录以外的目录,说明你一定没有删除干净,一定没有删除干净,一定没有删除干净,重要的事情说三遍,自己再仔细检查一下!  
另外,删除其他工程中armeabi-v7a, arm64_v8a,x86_64目录不会影响这些工程的功能的,也不会在其他手机上产生适配问题,所以放心的删除吧!  
另外,删除其他工程中armeabi-v7a, arm64_v8a,x86_64目录不会影响这些工程的功能的,也不会在其他手机上产生适配问题,所以放心的删除吧!  
另外,删除其他工程中armeabi-v7a, arm64_v8a,x86_64目录不会影响这些工程的功能的,也不会在其他手机上产生适配问题,所以放心的删除吧!  
重要的事情说三遍!!!  
so加载原理可以参考: http://www.jianshu.com/p/cb05698a1968


然后呢,我也找了一些瘦身APK的资料,发现好像只保留armeabi这个文件就可以了,别问为什么,微信就只有这一个文件夹,要是觉得自己apk太大了, 就删掉其他的吧,保留这一个就ok了。
参考见:
http://blog.csdn.net/a774838634/article/details/52758096
1.apk中有对应平台的文件夹,但是文件夹里却没有对应的so。
举个例子,apk中lib下面一旦出现x86文件夹,程序运行的时候就会去加载x86对应的库,但是如果此时x86文件夹没有将so放进来,则会遇到报错。
2.第三方对平台的兼容策略与自己不一致。
可能第三方选择了只支持armeabi(假设某支付sdk),但是我们的游戏在Application.mk中配置了APP_ABI := all,如此,我们的游戏打包出 了所有平台的so,但是第三方却只有armeabi文件夹对应的so,造成程序运行异常,这种情况在开发期间最常见,一些小公司由于测试人员不足或者测试设备不足,上线后才发现这个问题也不奇怪。
二、对于平台的支持,我们应该如何选择。
armeabi-v7a确实是可以兼容armeabi的,而v7a的CPU支持硬件浮点运算,目前绝大对数设备已经是v7a了,所以为了性能上的更优,就不要为了兼容放到armeabi。 x86是可以兼容armeabi平台运行的,无论是armeabi-v7a还是armeabi,同时带来的也是性能上的损耗,另外需要指出的是,打包出的x86的so,总会比armeabi平台的体积更小,对于性能有洁癖的童鞋们,还是建议在打包so的时候支持x86。具体会有怎样的性能损耗,作者还不能说的非常清楚,可以访问下intel官方在csdn的博客。 总结一下在项目中的表现就是: 
如果项目只包含了 armeabi,那么在所有Android设备都可以运行; 如果项目只包含了 armeabi-v7a,除armeabi架构的设备外都可以运行; 如果项目只包含了 x86,那么armeabi架构和armeabi-v7a的Android设备是无法运行的; 如果同时包含了 armeabi, armeabi-v7a和x86,所有设备都可以运行,程序在运行的时候去加载不同平台对应的so,这是较为完美的一种解决方案,同时也会导致包变大。
参考见:
http://blog.csdn.net/duguang77/article/details/38512957

这篇关于关于Java.lang.UnsatisfiedLinkError的错误解决办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113313

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定