[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文件放入该文件夹下对应的文件夹里就可以正常运行了。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值