UDS的解包算法,网络层解包算法

本文介绍了UDS(统一诊断服务)中,针对ISO15765协议的网络层解包算法。通过测试代码展示了如何将接收到的数据转化为应用层可理解的形式。
摘要由CSDN通过智能技术生成

测试代码:

String str1="A55A2018DA10FA101862C88201050104";
		String str2="A55A2018DA10FA21012C010082000005";	
		String str3="A55A2018DA10FA22B90000FA00012C06";
		String str4="A55A2018DA10FA2364012C64FFFFFF07";
		List<String> strList=new ArrayList();
		strList.add(str1);	strList.add(str2);	strList.add(str3);strList.add(str4);
		ArrayList<Byte> listBy=J1939Utils.UnPackCANFrameData(strList);		
		System.out.println(listBy.toString());

结果:
[98, -56, -126, 1, 5, 1, 1, 44, 1, 0, -126, 0, 0, -71, 0, 0, -6, 0, 1, 44, 100, 1, 44, 100]

/---------------ISO15765协议的解包算法(网络层–>应用层)------------------/

public static ArrayList<Byte> UnPackCANFrameData(List<String> receiveBuf){
   
	int dataLength = 0;
	ArrayList<Byte> receiveData = new ArrayList<Byte>();
	if((J1939Utils.int2bytes2(receiveBuf.get(0))[7]&0xf0) == 0x10){
   	//第一帧 first frame
		//获取该条报文的长度
		dataLength = ((J1939Utils.int2bytes2(receiveBuf.get(0))[7]&0x0f)<<8)+J1939Utils.int2bytes
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鼾声鼾语

感谢您的支持鼓励!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值