【DBC专题】-10-CAN DBC转换C语言代码Demo_接收Rx报文篇
案例背景(共15页精讲):
该篇博文将告诉您,CAN DBC转换C语言代码Demo,只需传递对应CAN信号关联参数,无需每个信号"左移"和"右移",并举例介绍:在CANoe/Canalyzer中CAPL中的应用:对接收报文,进行解包。其它场景的应用,也可参考该篇。
目录
1 背景:CAN信号在CAN 报文/Frame中位置的决定因素
2 讲解:CAN DBC转换C语言代码Demo
2.1 定义一些宏定义
2.2 定义一些结构体
2.3 API接口函数原型
2.4 对CANFD DBC的支持
2.5 如何使用该API接口
3 举例:在CANoe/Canalyzer中CAPL中的应用:对接收报文,进行解包
3.1 信号的字节顺序Byte Order: Intel小端模式
3.1.1 CAPL文件can的完整代码
3.1.2 系统变量定义
3.1.3 测试结果
3.2信号的字节顺序Byte Order: Motorola大端模式
3.2.1 CAPL文件can的完整代码
3.2.2 系统变量定义
3.2.3 测试结果
结尾
优质博文推荐阅读(单击下方链接,即可跳转):
Vector工具链
CAN Matrix DBC
CAN Matrix Arxml
1 背景:CAN信号在CAN 报文/Frame中位置的决定因素
一个CAN信号在CAN 报文/Frame中的位置,由3个条件决定,见图1-1:
- 信号的起始位Startbit:默认为信号的Lsb;
- 信号的长度Length;
- 信号的字节顺序Byte Order: Intel小端模式和Motorola大端模式。
详见博文“【DBC专题】-4-DBC文件中的Signal信号字节顺序Motorola和Intel介绍
https://blog.csdn.net/qfmzhu/article/details/111561710”,这里不再重复讲解。
下面我们根据这个背景,来设计一个通用算法,封装成一个函数,只需输入几个参数,即可得到对应的信号值。

图1-1
2 讲解:CAN DBC转换C语言代码Demo
2.1 定义一些宏定义
#define FRAME_TJW_ZERO_DLC 0 // unit:Byte
#define FRAME_TJW_MAX_DLC 8 // unit:Byte
#define SIGNAL_TJW_ZERO_LENGTH 0 // unit:Bit
#define SIGNAL_TJW_MAX_LENGTH 64 // unit:Bit
#define SIGNAL_TJW_INIT_VALUE 0
#define SIGNAL_TJW_INIT_MASK 0#define SIGNAL_TJW_BYTE_ORDER_INTEL 0
#define SIGNAL_TJW_BYTE_ORDER_MOTOROLA 1#define CAN_SIGNAL_TJW_NORMAL 0
#define CAN_SIGNAL_TJW_NO_VALUE 1
#define CAN_FRAME_TJW_DLC_OUT_OF_RANGE 2
#define INVALID_INPUT_PARAMETERS_TJW 3/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
2.2 定义一些结构体
typedef struct
{uint8 Signal_State; // Describes the state of a signaluint64 Signal_Value; // Describes the value of a signal
} Unpack_CAN_Signal;
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
2.3 API接口函数原型
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/Unpack_CAN_Signal Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex_Fun(
uint8* data_buff, /**Byte array of CAN data field**/
uint8 signal_start_bit, /**Rang:0~(FRAME_TJW_MAX_DLC * 8 - 1)**/
uint8 signal_length, /**Rang:1~SIGNAL_TJW_MAX_LENGTH**/
boolean signal_byte_order, /**0:Intel;1:Motorola**/
uint8 frame_length) /**Rang:1~FRAME_TJW_MAX_DLC**/
{Unpack_CAN_Signal can_signal;uint8 i = 0;uint8 byte_num = 0;uint8 low_data_byte = 0;uint8 high_data_byte = 0;uint8 low_data_byte_position = 0;uint8 high_data_byte_position = 0;uint8 remaining_bit_number = 0;uint8 remaining_byte_number = 0; uint64 can_signal_mask = SIGNAL_TJW_INIT_MASK;can_signal.Signal_State = CAN_SIGNAL_TJW_NORMAL;can_signal.Signal_Value = SIGNAL_TJW_INIT_VALUE;if(frame_length == FRAME_TJW_ZERO_DLC) /**DLC of CAN frame is 0**/{can_signal.Signal_State = CAN_SIGNAL_TJW_NO_VALUE;}else if(frame_length > FRAME_TJW_MAX_DLC) /**DLC of CAN frame is out of range**/{can_signal.Signal_State = CAN_FRAME_TJW_DLC_OUT_OF_RANGE;}else if((signal_length > (frame_length * 8)) /**Invalid signal_length: The length of the signal is not in the range of DLC**/|| (signal_length > SIGNAL_TJW_MAX_LENGTH) /**Invalid signal_length: The length of the signal exceeds the maximum Unsigned of C language**/|| (signal_length == SIGNAL_TJW_ZERO_LENGTH) /**Invalid signal_length: The length of the signal is not equal to 0**/ ){can_signal.Signal_State = INVALID_INPUT_PARAMETERS_TJW;}else{ /**Byte Order: Intel**/if(signal_byte_order == SIGNAL_TJW_BYTE_ORDER_INTEL) {/**Bytes used by CAN signal,Byte[0] is low byte,Byte[frame_length] is high byte**/low_data_byte = signal_start_bit / 8;high_data_byte = (signal_start_bit + signal_length - 1) / 8; // 2 + 6 - 1 /8 = 0; 2 + 7 - 1 /8 = 1 ; 2 + 14 - 1 /8 = 1 ; 2 + 15 - 1 /8 = 2if((high_data_byte + 1) > frame_length) /** CAN signal is not in the range of DLC**/{can_signal.Signal_State = CAN_FRAME_TJW_DLC_OUT_OF_RANGE;}else{for(i = 0;i < signal_length;i++) /**Generate signal mask according to signal length**/{can_signal_mask |= 0x0000000000000001 << i;}low_data_byte_position = signal_start_bit % 8; /**Distance from the lowest bit of each byte**//**CAN Signal is in a bytes**/if(low_data_byte == high_data_byte) { can_signal.Signal_Value = (((uint64)data_buff[low_data_byte]) >> low_data_byte_position) & can_signal_mask; }/**CAN Signal in multiple bytes**/else{ for(byte_num = low_data_byte;byte_num <= high_data_byte;byte_num++){if(byte_num == low_data_byte){can_signal.Signal_Value |= ((uint64)data_buff[low_data_byte]) >> low_data_byte_position;}else{can_signal.Signal_Value |= ((uint64)data_buff[byte_num]) << ((byte_num - low_data_byte - 1) * 8 + (8 - low_data_byte_position));} }can_signal.Signal_Value = can_signal.Signal_Value & can_signal_mask; } }}/**Byte Order: Motorola**/else /**signal_byte_order == SIGNAL_TJW_BYTE_ORDER_MOTOROLA**/{/**Bytes used by CAN signal,Byte[0] is low byte,Byte[frame_length] is high byte**/high_data_byte = signal_start_bit / 8; if((high_data_byte + 1) > frame_length) /** CAN signal is not in the range of DLC**/{can_signal.Signal_State = CAN_FRAME_TJW_DLC_OUT_OF_RANGE;}else{for(i = 0;i < signal_length;i++) /**Generate signal mask according to signal length**/{can_signal_mask |= 0x0000000000000001 << i;}high_data_byte_position = signal_start_bit % 8; /**Distance from the lowest bit of each byte**//**CAN Signal is in a bytes**/if(signal_length <= (8 - high_data_byte_position)){ can_signal.Signal_Value = (((uint64)data_buff[high_data_byte]) >> high_data_byte_position) & can_signal_mask; }/**CAN Signal in multiple bytes**/else{ remaining_bit_number = signal_length - (8 - high_data_byte_position); // 剩余bit = 12 - (8 - 2) = 6if((remaining_bit_number % 8) != 0) {remaining_byte_number = remaining_bit_number / 8 + 1; // remaining_byte_number = 1}else{remaining_byte_number = remaining_bit_number / 8;}for(byte_num = high_data_byte;byte_num >= (high_data_byte - remaining_byte_number);byte_num--) // high_data_byte = 2 remaining_byte_number = 1{ if(byte_num == high_data_byte){can_signal.Signal_Value |= ((uint64)data_buff[high_data_byte]) >> high_data_byte_position;}else{can_signal.Signal_Value |= ((uint64)data_buff[byte_num]) << ((high_data_byte - byte_num - 1) * 8 + (8 - high_data_byte_position));} if(byte_num == 0) {break;} }can_signal.Signal_Value = can_signal.Signal_Value & can_signal_mask; } } }}return can_signal;
}
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
2.4 对CANFD DBC的支持
只需将宏定义FRAME_TJW_MAX_DLC的值由8调整为64,即可适配CANFD DBC。
2.5 如何使用该API接口
1、提供的demo,使用了uint8,uint64,boolean类型,在将该代码集成至开发环境中,需要注意这些类型的替换:
- typedef unsigned char uint8
- typedef unsigned long long uint64
2、调用函数Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex_Fun时,需要确认传参data_buff,signal_start_bit,signal_length,signal_byte_order,frame_length的准确性,需与DBC保持一致,这样您可以得到对应信号的状态与值;
3 举例:在CANoe/Canalyzer中CAPL中的应用:对接收报文,进行解包
CAPL语法和C语言有一些差异,我们将第2.3章节中的demo稍作修改,以满足测需要。其它场景的应用与其类似。
3.1 信号的字节顺序Byte Order: Intel小端模式
3.1.1 CAPL文件can的完整代码
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
/*@!Encoding:936*/
includes
{}variables
{byte CAN_Data_Byte[8];byte Signal_State;word Signal_Value;
}on message 0x100
{CAN_Data_Byte[0] = this.byte(0);CAN_Data_Byte[1] = this.byte(1);CAN_Data_Byte[2] = this.byte(2);CAN_Data_Byte[3] = this.byte(3);CAN_Data_Byte[4] = this.byte(4); CAN_Data_Byte[5] = this.byte(5); CAN_Data_Byte[6] = this.byte(6);CAN_Data_Byte[7] = this.byte(7);@sysvar::CAN_Frame::sysvar_Test_Signal_1 = Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(0,2,8);@sysvar::CAN_Frame::sysvar_Test_Signal_2 = Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(50,12,8);@sysvar::CAN_Frame::sysvar_Test_Signal_3 = Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(62,2,8);
}word Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(
byte signal_start_bit, /**Rang:0~(8 * 8 - 1)**/
byte signal_length, /**Rang:1~64**/
byte frame_length) /**Rang:1~8**/
{byte i = 0;byte byte_num = 0;byte low_data_byte = 0;byte high_data_byte = 0;byte low_data_byte_position = 0;byte high_data_byte_position = 0;byte remaining_bit_number = 0;byte remaining_byte_number = 0; word can_signal_mask = 0;Signal_State = 0;Signal_Value = 0;if(frame_length == 0) /**DLC of CAN frame is 0**/{Signal_State = 1;}else if(frame_length > 8) /**DLC of CAN frame is out of range**/{Signal_State = 2;}else if((signal_length > (frame_length * 8)) /**Invalid signal_length: The length of the signal is not in the range of DLC**/|| (signal_length > 16) /**Invalid signal_length: The length of the signal exceeds the maximum Unsigned of C language**/|| (signal_length == 0) /**Invalid signal_length: The length of the signal is not equal to 0**/ ){Signal_State = 3;}else{/**Byte Order: Intel**/{/**Bytes used by CAN signal,Byte[0] is low byte,Byte[frame_length] is high byte**/low_data_byte = signal_start_bit / 8;high_data_byte = (signal_start_bit + signal_length - 1) / 8; // 2 + 6 - 1 /8 = 0; 2 + 7 - 1 /8 = 1 ; 2 + 14 - 1 /8 = 1 ; 2 + 15 - 1 /8 = 2if((high_data_byte + 1) > frame_length) /** CAN signal is not in the range of DLC**/{Signal_State = 2;}else{ for(i = 0;i < signal_length;i++) /**Generate signal mask according to signal length**/{can_signal_mask |= 0x0000000000000001 << i;}low_data_byte_position = signal_start_bit % 8; /**Distance from the lowest bit of each byte**//**CAN Signal is in a bytes**/if(low_data_byte == high_data_byte) { Signal_Value = (((word)CAN_Data_Byte[low_data_byte]) >> low_data_byte_position) & can_signal_mask; }/**CAN Signal in multiple bytes**/else{ for(byte_num = low_data_byte;byte_num <= high_data_byte;byte_num++){ if(byte_num == low_data_byte){ Signal_Value |= ((word)CAN_Data_Byte[low_data_byte]) >> low_data_byte_position;}else{ Signal_Value |= ((word)CAN_Data_Byte[byte_num]) << ((byte_num - low_data_byte - 1) * 8 + (8 - low_data_byte_position));} }Signal_Value = Signal_Value & can_signal_mask; } }}}return Signal_Value;
}
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
3.1.2 系统变量定义

3.1.3 测试结果
使用的DBC:

CAN DBC中信号与系统变量的解析结果一致:

3.2信号的字节顺序Byte Order: Motorola大端模式
3.2.1 CAPL文件can的完整代码
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
/*@!Encoding:936*/
includes
{}variables
{byte CAN_Data_Byte[8];byte Signal_State;word Signal_Value;
}on message 0x100
{CAN_Data_Byte[0] = this.byte(0);CAN_Data_Byte[1] = this.byte(1);CAN_Data_Byte[2] = this.byte(2);CAN_Data_Byte[3] = this.byte(3);CAN_Data_Byte[4] = this.byte(4); CAN_Data_Byte[5] = this.byte(5); CAN_Data_Byte[6] = this.byte(6);CAN_Data_Byte[7] = this.byte(7); @sysvar::CAN_Frame::sysvar_Test_Signal_4 = Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(6,2,8);@sysvar::CAN_Frame::sysvar_Test_Signal_5 = Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(10,12,8);@sysvar::CAN_Frame::sysvar_Test_Signal_6 = Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(56,2,8);
}word Rx_CAN_Frame_Data_Buff_to_CAN_Signal_Hex(
byte signal_start_bit, /**Rang:0~(8 * 8 - 1)**/
byte signal_length, /**Rang:1~64**/
byte frame_length) /**Rang:1~8**/
{byte i = 0;byte byte_num = 0;byte low_data_byte = 0;byte high_data_byte = 0;byte low_data_byte_position = 0;byte high_data_byte_position = 0;byte remaining_bit_number = 0;byte remaining_byte_number = 0; word can_signal_mask = 0;Signal_State = 0;Signal_Value = 0;if(frame_length == 0) /**DLC of CAN frame is 0**/{Signal_State = 1;}else if(frame_length > 8) /**DLC of CAN frame is out of range**/{Signal_State = 2;}else if((signal_length > (frame_length * 8)) /**Invalid signal_length: The length of the signal is not in the range of DLC**/|| (signal_length > 16) /**Invalid signal_length: The length of the signal exceeds the maximum Unsigned of C language**/|| (signal_length == 0) /**Invalid signal_length: The length of the signal is not equal to 0**/ ){Signal_State = 3;}else{/**Byte Order: Motorola**/{/**Bytes used by CAN signal,Byte[0] is low byte,Byte[frame_length] is high byte**/high_data_byte = signal_start_bit / 8; if((high_data_byte + 1) > frame_length) /** CAN signal is not in the range of DLC**/{Signal_State = 2;}else{for(i = 0;i < signal_length;i++) /**Generate signal mask according to signal length**/{can_signal_mask |= 0x0000000000000001 << i;}high_data_byte_position = signal_start_bit % 8; /**Distance from the lowest bit of each byte**//**CAN Signal is in a bytes**/if(signal_length <= (8 - high_data_byte_position)){ Signal_Value = (((word)CAN_Data_Byte[high_data_byte]) >> high_data_byte_position) & can_signal_mask; }/**CAN Signal in multiple bytes**/else{ remaining_bit_number = signal_length - (8 - high_data_byte_position); // 剩余bit = 12 - (8 - 2) = 6if((remaining_bit_number % 8) != 0) {remaining_byte_number = remaining_bit_number / 8 + 1; // remaining_byte_number = 1}else{remaining_byte_number = remaining_bit_number / 8;}for(byte_num = high_data_byte;byte_num >= (high_data_byte - remaining_byte_number);byte_num--) // high_data_byte = 2 remaining_byte_number = 1{ if(byte_num == high_data_byte){Signal_Value |= ((word)CAN_Data_Byte[high_data_byte]) >> high_data_byte_position;}else{Signal_Value |= ((word)CAN_Data_Byte[byte_num]) << ((high_data_byte - byte_num - 1) * 8 + (8 - high_data_byte_position));} if(byte_num == 0) {break;} }Signal_Value = Signal_Value & can_signal_mask; } } }}return Signal_Value;
}
/** 使用该Demo需注明出处,以表对作者的尊重 **/
/** 版权归CSDN博客“汽车电子助手”所有,https://blog.csdn.net/qfmzhu **/
3.2.2 系统变量定义

3.2.3 测试结果
使用的DBC:

CAN DBC中信号与系统变量的解析结果一致:

结尾
获取更多“汽车电子资讯”和“工具链使用”,
请关注CSDN博客“汽车电子助手”,做您的好助手。
相关文章:
【DBC专题】-10-CAN DBC转换C语言代码Demo_接收Rx报文篇
案例背景(共15页精讲): 该篇博文将告诉您,CAN DBC转换C语言代码Demo,只需传递对应CAN信号关联参数,无需每个信号"左移"和"右移",并举例介绍:在CANoe/Canalyzer中CAPL中的应用ÿ…...
AtCoder292 E 思维
题意: 给定一副n(n≤3000)n(n\leq 3000)n(n≤3000)个顶点,mmm条有向边的图,可以在图中添加有向边,求添加的最少边数,使得这副图满足:如果顶点aaa到顶点bbb有边,顶点bbb到ccc右有边,…...
20230309英语学习
What Is Sleep Talking? We Look at the Science 为什么人睡觉会说梦话?来看看科学咋说 Nearly everyone has a story about people talking in their sleep.Though it tends to be more common in children, it can happen at any age:A 2010 study in the jour…...
CAD转换PDF格式怎么弄?教你几种方法轻松搞定!
CAD是从事与艺术创作相关等行业的打工人们必需的工作软件,可以用来完成建筑设计图、设计图纸等。在日常的工作中,一些伙伴经常需要传输图纸给合作方来完成探讨。但是CAD图纸需要使用专业软件才能打开,这就给文件传送带来了一定的困难。而且传…...
AtCoder 259E LCM
题意: 以唯一分解形式给出nnn个数: aipi,1ei,1pi,2ei,2...pi,tei,ta_{i}p_{i,1}^{e_{i,1}}p_{i,2}^{e_{i,2}}...p_{i,t}^{e_{i,t}} aipi,1ei,1pi,2ei,2...pi,tei,t 现在可以将某个数改为111,求所有改法中,有多少个…...
MQTT协议-取消订阅和取消订阅确认
MQTT协议-取消订阅和取消订阅确认 客户端向服务器取消订阅 取消订阅的前提是客户端已经通过CONNECT报文连接上服务器,并且订阅了一个主题 UNSUBSCRIBE—取消订阅 取消订阅的报文同样是由固定报头可变报头有效载荷组成 固定报头由两个字节组成,第一个…...
90后小伙,用低代码“整顿”旅游业,年入2000万,他是怎么做到的?
热爱旅游的92年成都小伙猴哥,大学毕业后开了一家旅行社,主要从事川藏、云南定制游服务。 从今年春节开始,国内各地旅游业开始复苏,向旅行社打电话咨询的人越来越多。 旅游的人多是好事,也是一种烦恼,因为…...
C51---PWM 脉冲宽度调制
1.PWM:脉冲宽度调制,它是通过一系列脉冲宽度进行调制,等效出所需要的波形(包含形状以及幅值)。对模拟信号电平进行数字编码。也就是说通过调节占空比的变化来调节信号、能量等的变化,占空比就是指在一个周期内,信号处于…...
毕业设计 基于51单片机WIFI智能家居系统设计
基于51单片机WIFI智能家居系统设计1、毕业设计选题原则说明(重点)2、项目资料2.1 系统框架2.2 系统功能3、部分电路设计3.1 STC89C52单片机最小系统电路设计3.2 ESP8266 WIFI电路设计3.3 DHT11温湿度传感器电路设计4、部分代码展示4.1 LCD12864显示字符串…...
Nginx服务优化措施与配置防盗链
目录 一.优化Nginx的相关措施 二.隐藏/查看版本号 三.修改用户与组 四.设置缓存时间 五.日志切割脚本 六.设置连接超时控制连接访问时间 七.开启多进程 八.配置网页压缩 九.配置防盗链 1.配置web源主机(192.168.79.210 www.zhuo.com) 1.1 安装…...
Java 某厂面试题真题合集
哈喽~大家好,这篇来看看Java 某厂面试题真题合集。 🥇个人主页:个人主页 🥈 系列专栏:【日常学习上的分享】 🥉与这篇相关的文章: Spr…...
很特别的5G市场,5.75亿部手机,却有11亿5G用户,这是怎么了?
中国在5G商用方面已取得了巨大的成绩,这是毋庸置疑的,不过近期公布的一份数据却相当特别,5G手机用户数为5.75亿,而开通了5G套餐的用户数却已超过11亿,这数据对比有点意思。中国在5G商用方面推进很快,建成的…...
go modules
文章目录1. 简介示例1. 示例——同一项目2. 示例——不同项目3. 示例——添加远程模块依赖库1. 简介 go module是Go1.11版本之后官方推出的版本管理工具,并且从Go1.13版本开始,go module将是Go语言默认的依赖管理工具。到今天Go1.14版本推出之后Go modu…...
Baklib客户故事:快递助手ERP
快递助手ERP以多平台多店铺订单管理为核心,集打单发货、商品、库存、采购、售后于一体,中小商家易上手的轻量级ERP,可以满足满足微商、自建商城、档口货源网、一件代发等不同类型客户的打单需求,通过开放平台API接口,自…...
MongoDB学习(java版)
MongoDB概述 结构化数据库 结构化数据库是一种使用结构化查询语言(SQL)进行管理和操作的数据库,它们的数据存储方式是基于表格和列的。结构化数据库要求数据预先定义数据模式和结构,然后才能存储和查询数据。结构化数据库通常…...
RK3568平台开发系列讲解(显示篇)什么是DRM
🚀返回专栏总目录 文章目录 一、DRM介绍二、DRM与framebuffer的区别沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇文章将介绍什么是DRM。 一、DRM介绍 DRM 是 Linux 目前主流的图形显示框架,相比FB架构,DRM更能适应当前日益更新的显示硬件。 比如FB原生不支…...
Python蓝桥杯训练:基本数据结构 [二叉树] 上
Python蓝桥杯训练:基本数据结构 [二叉树] 上 文章目录Python蓝桥杯训练:基本数据结构 [二叉树] 上一、前言二、有关二叉树理论基础1、二叉树的基本定义2、二叉树的常见类型3、二叉树的遍历方式三、有关二叉树的层序遍历的题目1、[二叉树的层序遍历](http…...
vuex基础之初始化功能、state、mutations、getters、模块化module的使用
vuex基础之初始化功能、state、mutations、getters、模块化module的使用一、Vuex的介绍二、初始化功能三、state3.1 定义state3.2 获取state3.2.1 原始形式获取3.2.2 辅助函数获取(mapState)四、mutations4.1 定义mutations4.2 调用mutations4.2.1 原始形式调用($store)4.2.2 辅…...
WebSphere中间件漏洞总结
WebSphere中间件漏洞总结 一、WebSphere简介 WebSphere为SOA(面向服务架构)环境提供软件,以实现动态的、互联的业务流程,为所有业务情形提供高度有效的应用程序基础架构。WebSphere是IBM的应用程序和集成软件平台,包含所有必要的中间件基础架构(包括服务器、服务和工具)…...
Unity之ASE实现影魔灵魂收集特效
前言 我们今天来实现一下Dota中的影魔死亡后,灵魂收集的特效。效果如下: 实现原理 1.先添加一张FlowMap图,这张图的UV是根据默认UV图,用PS按照我们希望的扭曲方向修改的如下图所示: 2.通过FlowMap图,我…...
Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...
【网络】每天掌握一个Linux命令 - iftop
在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...
VB.net复制Ntag213卡写入UID
本示例使用的发卡器:https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...
JavaScript 中的 ES|QL:利用 Apache Arrow 工具
作者:来自 Elastic Jeffrey Rengifo 学习如何将 ES|QL 与 JavaScript 的 Apache Arrow 客户端工具一起使用。 想获得 Elastic 认证吗?了解下一期 Elasticsearch Engineer 培训的时间吧! Elasticsearch 拥有众多新功能,助你为自己…...
剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...
uniapp微信小程序视频实时流+pc端预览方案
方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度WebSocket图片帧定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐RTMP推流TRTC/即构SDK推流❌ 付费方案 (部分有免费额度&#x…...
NFT模式:数字资产确权与链游经济系统构建
NFT模式:数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新:构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议:基于LayerZero协议实现以太坊、Solana等公链资产互通,通过零知…...
高防服务器能够抵御哪些网络攻击呢?
高防服务器作为一种有着高度防御能力的服务器,可以帮助网站应对分布式拒绝服务攻击,有效识别和清理一些恶意的网络流量,为用户提供安全且稳定的网络环境,那么,高防服务器一般都可以抵御哪些网络攻击呢?下面…...
3-11单元格区域边界定位(End属性)学习笔记
返回一个Range 对象,只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意:它移动的位置必须是相连的有内容的单元格…...
