[rxtxSerial.dll+0x4465]及打包运行后遇到的坑
在项目引入rxtx时遇到的坑。
一、下载安装
先从下载对应包开始:
1.去下载http://rxtx.qbang.org/wiki/index.php/Download
因为我的windows是64位的,所以要去下载64位的,去64位的下载页面,拉到下面,下载Windows-x64的压缩包
解压后有如下文件:
查看Install.txt可以知道不同操作系统都要怎么使用,window下使用如下:
即将RXTXcomm.jar复制到自己电脑的jdk安装路径下的jre\lib\ext文件夹里,忘记了的可以去高级系统设置的环境变量里面看,我电脑的是这里:
同理,rxtxSerial.dll和rxtxParaler.dll放到jdk安装路径的jre\bin文件夹里:
二、[rxtxSerial.dll+0x4465]
在环境弄好之后,运行项目,结果项目跑不起来,报了下面的错:
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x0000000180004465, pid=6036, tid=0x0000000000002618
#
# JRE version: Java(TM) SE Runtime Environment (8.0_291-b10) (build 1.8.0_291-b10)
# Java VM: Java HotSpot(TM) 64-Bit Server VM (25.291-b10 mixed mode windows-amd64 compressed oops)
# Problematic frame:
# C [rxtxSerial.dll+0x4465]
#
# Failed to write core dump. Minidumps are not enabled by default on client versions of Windows
#
# If you would like to submit a bug report, please visit:
# http://bugreport.java.com/bugreport/crash.jsp
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
在查了很久之后发现,之貌似是个jdk版本冲突的问题,我电脑一开始安装的版本是jdk1.8.0_291,我把jdk版本换成jdk1.8.0_211后就不报错了,下面是我电脑两个版本的jdk:
更换了jdk版本后要记得重新第一步rxtx的安装。
三、java.lang.NoClassDefFoundError: gnu/io/SerialPortEventListener
在将项目打包成jar包后本地用命令java -jar xxx.jar运行时,会发现程序找不到
SerialPortEventListener这个类,这个类是在RXTXcomm.jar包里的,也就是说rxtx运行的环境并没有弄好。
Exception in thread "Thread-3" java.lang.NoClassDefFoundError: gnu/io/SerialPortEventListener
at com.thyme.zhcj.rxtx.CollectThread.run(CollectThread.java:80)
Caused by: java.lang.ClassNotFoundException: gnu.io.SerialPortEventListener
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at org.springframework.boot.loader.LaunchedURLClassLoader.loadClass(LaunchedURLClassLoader.java:92)
at java.lang.ClassLoader.loadClass(Unknown Source)
... 1 more
这是因为我只将RXTXcomm.jar那三个文件放到了开发时jdk的jre里面,但在运行时,java的运行环境是在jdk安装时选定的jre安装路径里的,也就是下面那个文件夹:
按第一步的步骤把jar包和两个dll文件放入该文件夹下对应的文件夹里就可以正常运行了。