C++中内存对齐导致memcpy出错

更新时间:2023-07-16 11:12:33 阅读: 评论:0

C++中内存对齐导致memcpy出错
typedef unsigned char      uint8_t;
typedef unsigned short    uint16_t;
typedef unsigned int      uint32_t;
typedef struct
联句>薯包籺
{
有下列情形之一的uint8_t Analog_Out_En;//模拟输出使能信号
uint8_t Analog_Out_Source;//模拟输出信号源
爆笑gif图
uint8_t Analog_Out_Mode;//模拟输出模式:0-电压,1-电流
int32_t A_Distance_StartPoint;//输出起点,100mm
水库钓鱼int32_t A_Distance_EndPoint;//输出终点,300mm
int32_t A_Map_StartPoint;//模拟输出映射起点,如0V
int32_t A_Map_EndPoint;//模拟输出映射终点,如10V
} ANALOG_OUT_PARAM;
char ptr[]="\x3F\xF3\x00\x19\x00\xDA\x01\x01\x01\x02\x01\xFC\x0F\x42\x40\x00\x1E\x84\x80\x00\x2D\xC6\xC0\x00\x3D\x09\x00\xDE\x45";
ANALOG_OUT_PARAM param[2];
荷兰红屋>病梅std::cout <<sizeof(ANALOG_OUT_PARAM);
param[0].Analog_Out_En = ptr[8];
memt(¶m[0].Analog_Out_En,0xFF,2*sizeof(ANALOG_OUT_PARAM));
memcpy(¶m[0].Analog_Out_En, ptr +8,19);
使⽤memcpy复制数据的时候,中间的0xFC字节消失了,Analog_Out_En,⽽0xFC后⾯数据整体向前移了⼀个字节,造成赋值错误,这是因为结构内存体为4字节对齐,Analog_Out_En,Analog_Out_
拔智齿后吃什么Source,Analog_Out_Mode为三个字节,A_Distance_StartPoint为四个字节,对齐到四个字节,所以在Analog_Out_Mode和A_Distance_StartPoint之间隐藏了⼀个⽤于对齐的字节,FC的值便赋给了该隐藏字节,造成后⾯的字节往前移了⼀位。

本文发布于:2023-07-16 11:12:33,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/82/1099539.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:字节   模拟输出   造成   数据   内存
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图