CAN-do-paser:Java开发的CAN总线数据帧解析库

1 CAN总线数据解析示例

1.1 安装依赖

更新: 暂时没有提交到maven中央仓库。

1.2 对CAN数据帧解析为十进制数据

CANFrame canFrame = new CANFrame(System.currentTimeMillis(), 1, 8, 20, "275d602702000000");

// 解析具体的信号
int startBit = 32;
int length = 32;
boolean isSigned = true;
boolean isLittleEndian = true;
String factor = "1";
String offset = "0";

// 解析工具的静态解析方法,对信号进行解析
double signal = CANFrameParser.extractSignal(canFrame.getMsgData(), startBit, length, isSigned, 
                isLittleEndian, factor, offset);

2 CAN总线数据DBC文件解析

String filePath = "xxx.dbc";

// 对dbc文件进行解析
Map<DbcMessage, List<DbcSignal>> dbcMessageListMap = DbcParser.parseFile(filePath);

3 解析方案

3.1 CAN数据帧中的大小端差异

解析工具中根据大小端进行分别解析,具体的差异请阅读代码。

3.2 二进制转为浮点数的标准协议IEEE754

该标准的全称为IEEE二进制浮点数算术标准(ANSI/IEEE Std 754-1985),又称IEC 60559:1989,微处理器系统的二进制浮点数算术.

一个浮点数 (Value) 的表示其实可以这样表示:

Value = sign * exponent * fraction

也就是浮点数的实际值,等于符号位(sign bit)乘以指数偏移值(exponent bias)再乘以分数值(fraction)。

4 代码地址

https://github.com/Jarrettluo/CAN-do-parser

如果有解析不正确的请在仓库中提出issue

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值