C语言的TLV装包与解析

2024-01-04 23:50
文章标签 语言 解析 装包 tlv

本文主要是介绍C语言的TLV装包与解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是TLV?

哈哈哈哈哈哈,碰见新东西,先来一手我的学习三大问:这是什么?有什么用?怎么做?
先了解下TLV——BER编码的一种,ASN1标准,由Tag(标签),Length(长度),Value(值)而来。what?我一看,前面两个又没听过,怎嘛办,上百度查了查,这么高大的出身,我这代码写的都觉得对不起这个它。
ASN.1抽象语法标记(Abstract Syntax Notation One) ASN.1是一种 ISO/ITU-T 标准,描述了一种对数据进行表示、编码、传输和解码的数据格式。它提供了一整套正规的格式用于描述对象的结构,而不管语言上如何执行及这些数据的具体指代,也不用去管到底是什么样的应用程序。ASN.1 取得成功的一个主要原因是它与几个标准化编码规则相关,如基本编码规则BER) -X.209 、规范编码规则(CER)、识别名编码规则(DER)、压缩编码规则(PER)和 XML编码规则(XER)。1984年,ASN.1 就已经成为了一种国际标准

TLV的数据封装

它是一种按照tag,length,value这样的顺序来对数据进行封装的规则,在内存中如下图表示:
在这里插入图片描述
比如我们将要发送的数据是:0x03 0x06 0x32 0x31 0x32 0x35
按照TLV的定义:
其中0x03表示标签,表示这是哪一类的数据,不然你收到这样的数据是什么样的。
0x06表示这段数据总共有6个字节,包括tag和length。
后面的四个字节表示值。这样叫做一帧数据,假如收到了许多帧,那么仅仅依靠TAG来判断数据是会出问题的。比如:
0x03 0x03 0x32 0x03 0x03 0x03 0x03 哦豁,傻眼
这样就需要定义一个一帧数据的开始,HEAD,就变成了这样:
在这里插入图片描述
一帧数据的第一个字节定义为头,一般设为数据中最不可能出现的值,比如0xff。但是这样还是不好,万一我非要发0xff怎么办对吧,我就要搞它。不光是这样,我们封装好的数据再发送的过程中是通过物理层的电缆传输出去的,那么也就难免会出错(可能有人会说,在信道传输过程中本身就有纠错机制,都是概率问题,万一!!对吧)。比如后面的值由0x35变成0x31,对于一般的数据来说没什么影响,但假如这个值控制着某个警报,遇险情却没有报警。那就GG。有没什么方法可以对数据进行检错呢?确保自己收到的是正确的数据。对于这种纠错的暂时知道的奇偶校验CRC校验。奇偶校验就是判断数据中0或1的的个数,因为2个位同时出错的概率很低。关于CRC校验可参考https://blog.csdn.net/xing414736597/article/details/78693781
CRC算法可以通过数据算出一个CRC值,发送数据的一方可以先算出这个值,然后封装到这一帧数据的尾部,在数据的接受端采用同样的算法算出这个值再和数据尾部的这个值作比较,若果相等,则正确。CRC的实现可参考我代码中的两个文件,实现别人代码的最大复用,哈哈哈哈哈 “crc-itu-t.h”,“crc-itu-t.c” GitHub地址
这里用到了CRC-16,也就是两个字节,那么最后就可以表示成下面这样ÿ

这篇关于C语言的TLV装包与解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/570991

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Maven中生命周期深度解析与实战指南

《Maven中生命周期深度解析与实战指南》这篇文章主要为大家详细介绍了Maven生命周期实战指南,包含核心概念、阶段详解、SpringBoot特化场景及企业级实践建议,希望对大家有一定的帮助... 目录一、Maven 生命周期哲学二、default生命周期核心阶段详解(高频使用)三、clean生命周期核心阶

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹