解决”java.lang.UnsatisfiedLinkError: Native Library .dll already loaded in another classloader”的问题

JAVA启动后,是经过JVM各级ClassLoader来加载各个类到内存。为了更加了解加载过程,我通过分析和写了一个简单的ClassLoader来粗浅的分析它的原理。

JVM的ClassLoader分三层,分别为Bootstrap ClassLoader,Extension ClassLoader,System ClassLoader,他们不是类继承的父子关系,是逻辑上的上下级关系。

Bootstrap ClassLoader是启动类加载器,它是用C++编写的,从%jre%/lib目录中加载类,或者运行时用-Xbootclasspath指定目录来加载。

Extension ClassLoader是扩展类加载器,从%jre%/lib/ext目录加载类,或者运行时用-Djava.ext.dirs制定目录来加载。

System ClassLoader,系统类加载器,它会从系统环境变量配置的classpath来查找路径,环境变量里的.表示当前目录,是通过运行时-classpath或-Djava.class.path指定的目录来加载类。

可以通过下面三条语句,输入现在加载的各个classloader的加载路径:

System.out.println("sun.boot.class.path:" + System.getProperty("sun.boot.class.path"));

System.out.println("java.ext.dirs:" + System.getProperty("java.ext.dirs"));

System.out.println("java.class.path:" +System.getProperty("java.class.path"));

 1 sun.boot.class.path:
 2     C:\D\programsoft\Java\jre1.8.0_45\lib\resources.jar;
 3     C:\D\programsoft\Java\jre1.8.0_45\lib\rt.jar;
 4     C:\D\programsoft\Java\jre1.8.0_45\lib\sunrsasign.jar;
 5     C:\D\programsoft\Java\jre1.8.0_45\lib\jsse.jar;
 6     C:\D\programsoft\Java\jre1.8.0_45\lib\jce.jar;
 7     C:\D\programsoft\Java\jre1.8.0_45\lib\charsets.jar;
 8     C:\D\programsoft\Java\jre1.8.0_45\lib\jfr.jar;
 9     C:\D\programsoft\Java\jre1.8.0_45\classes
10
11 java.ext.dirs:
12     C:\D\programsoft\Java\jre1.8.0_45\lib\ext;
13     C:\WINDOWS\Sun\Java\lib\ext
14
15 java.class.path:
16     C:\Users\Mat Lei\workspace\FlexAndJava_Server\build\classes;
17     C:\D\basic\programsoft\Tomcat 8.0\lib\annotations-api.jar;
18     C:\D\basic\programsoft\Tomcat 8.0\lib\catalina-ant.jar;
19     C:\D\basic\programsoft\Tomcat 8.0\lib\catalina-ha.jar;
20     C:\D\basic\programsoft\Tomcat 8.0\lib\catalina-storeconfig.jar;
21     C:\D\basic\programsoft\Tomcat 8.0\lib\catalina-tribes.jar;
22     C:\D\basic\programsoft\Tomcat 8.0\lib\catalina.jar;
23     C:\D\basic\programsoft\Tomcat 8.0\lib\ecj-4.4.2.jar;
24     C:\D\basic\programsoft\Tomcat 8.0\lib\el-api.jar;
25     C:\D\basic\programsoft\Tomcat 8.0\lib\jasper-el.jar;
26     C:\D\basic\programsoft\Tomcat 8.0\lib\jasper.jar;
27     C:\D\basic\programsoft\Tomcat 8.0\lib\jsp-api.jar;
28     C:\D\basic\programsoft\Tomcat 8.0\lib\servlet-api.jar;

首先访问项目A的一个界面,界面中调用了appletA,接着并没有关闭浏览器而直接访问项目B的界面,在界面中调用了appletB。appletA和appletB实际上是同一个applet,只不过这个applet使用在了两个项目中,并且两个项目均是直接进行访问。这时候在访问appletB的时候,就会出现一个错误:

xxx NOT loaded java.lang.UnsatisfiedLinkError : Native Library XXX.dll already loaded in another classloader

如果访问从appletB到appletA,那么在访问appletA时也会出现同样的错误。
    因为,在一个标签页中,多个applet运行实际上是运行在同一个jvm上,只是加载applet时使用了不同的classLoader。因此,不管是 appletA先运行还是appletB先运行,最终情况都是所依赖的dll都会被同一个jvm所加载,就会出现以上的错误了。

在进行google之后,发现很多开发人员都碰到了同样的问题,有的是因为在同一个javaEE容器如(weblogic,jboss)中部署了两个都要 访问同一个jni调用的项目,有的则是像笔者同样的经历。最后的结论即是,在一个jvm当中,是不允许加载一个dll两次的。因此,后面的jni调用时, 尝试再次加载同一个dll,这时候即会报上面的错误了。因为该错误,相对应的java类肯定不能被初始化,因此相应的项目或者applet肯定启动不了了。

  解决办法是把调用dll的jar复制到C:\D\programsoft\Java\jre1.8.0_45\lib下,即Bootstrap ClassLoader加载的目录下,并在JRE System Library下添加该jar,并在

JRE System Library——Properties——Installed JREs——Edit——Add External JARs中选择该jar。即可在Bootstrap ClassLoader加载该JAR,并且不受线程限制。

参考内容:

http://www.cnblogs.com/newstar/archive/2012/03/14/2396176.html

http://www.cnblogs.com/Lawson/archive/2012/07/31/2616623.html

时间: 2024-08-09 23:45:33

解决”java.lang.UnsatisfiedLinkError: Native Library .dll already loaded in another classloader”的问题的相关文章

高德 java.lang.UnsatisfiedLinkError: Native method not found: com.autonavi.amap.mapc

我的项目是从eclipse上转到Android studio上的 结果发现在使用高德的时候报错了, 下面是错误信息: java.lang.UnsatisfiedLinkError: Native method not found:                                                                            com.autonavi.amap.mapcore.MapCore.nativeNewInstance:(Ljava/

搭建hadoop2.7.6环境以及解决java.lang.UnsatisfiedLinkError: org.apache.hadoop.io.nativeio.NativeIO$Windo问题

这些天开始慢慢接触大数据的东西,顺手些一下hadoop搭建过程,提供一下自己的经验. 首先,我查了很多博客之后,确定了自己需要安装的hadoop版本2.7.6并找到两个感觉比较好的博客,下面说一下安装过程以及解决问题的方法. 第一步,根据博客https://blog.csdn.net/u012761191/article/details/80501388来安装,其中,我用的jdk是1.8版本的,hadoopwindows-master的地址为: 链接:https://pan.baidu.com/

java.lang.UnsatisfiedLinkError:no dll in java.library.path终极解决之道

 Java调用Dll时,会出现no dll in java.library.path异常,在Java Project中不常见,因为只要将Dll拷贝到system32目录下即可:         但若是在Web Project中则经常遇见,因为Web Project引用的 java.library.path  有两处(jre的bin目录和Tomcat的bin目录) 因此解决方法如下: 1.在项目中执行System.out.println(System.getProperty("java.libra

J2EE引擎出现java.lang.UnsatisfiedLinkError: CC错误的原因

运行JSP报表程序页面出现java.lang.UnsatisfiedLinkError: CC错误有以下几种原因和处理方法: 1.请查看控制台的错误信息 a:如果控制台的消息是类似 java.lang.UnsatisfiedLinkError: no MRChkLib in java.library.path,Error loading library MRChkLib 这样的错误信息,那么是因为MRChkLib.dll没有拷贝到windows的System32目录下. (MRChkLib.dl

关于java.lang.UnsatisfiedLinkError的小案例

在许多项目中我们都会用到第三方动态库.so文件,但是往往会引来很多烦恼,比如:java.lang.UnsatisfiedLinkError 06-17 15:52:08.097 7876-7916/com.ishow.scan E/AndroidRuntime﹕ FATAL EXCEPTION: Thread-61542 java.lang.UnsatisfiedLinkError: Native method not found: com.ishow.scan.zbar.ZbarManager

android 使用讯飞人脸识别api报错:java.lang.UnsatisfiedLinkError

1.在做一个人脸识别的项目,使用的是讯飞的api,编辑器为AS2.0,运行时报如下错误: FATAL EXCEPTION: main                  Process: com.admin.smartcam, PID: 13821                  java.lang.UnsatisfiedLinkError: Native method not found: com.faceplusplus.api.Native.setMinFaceSize:(II)I    

java.lang.UnsatisfiedLinkError:no in java.library.path解决办法

在用exe4j打包java工程后,在其他电脑运行结果出现了  java.lang.UnsatisfiedLinkError:no  in java.library.path的错误,刚开始以为是jar包没在classpath路径中,后来才发现java.library.path与classpath是两个不同的变量,后者是我们所熟知的类路径,与jar包有关:而前者与dll有关,它指定dll文件搜索路径. 在我的工程中,用到了第三方jar包和dll文件,dll文件放在了工程根目录,在eclipse中

Exception in thread "main" java.lang.UnsatisfiedLinkError: Unable to load library 'dll.msvcrt'

上网找了一下方法,说是jdk64的问题,也有说是路径不对问题. 代码片段 1 public interface CLibrary extends Library { 2 CLibrary INSTANCE = (CLibrary) Native.loadLibrary("dll.msvcrt", 3 CLibrary.class); 4 void printf(String format, Object... args); 5 } 在看到以下文章之后,觉得loadLibrary()加载

使用Snappy 压缩方式报错“java.lang.UnsatisfiedLinkError: no snappyjava in java.library.path”

情况描述 其实这个问题已经困扰我很久了,最近在公司Linux上搭建hadoop 和 spark环境的时候,我就遇到 spark提交作业到yarn 集群就报错这个错,当时已经安装snappy环境了,任何关于snappy静态库都编译了,这是我提交到spark mail list上的http://apache-spark-user-list.1001560.n3.nabble.com/java-lang-UnsatisfiedLinkError-no-snappyjava-in-java-librar