我创建了一个具有以下结构的EFS项目
struct
{
uint8 version; // uint8 - 1 byte data type, uint16 - 2 byte
uint16 y1;
uint16 y2;
uint16 y3;
uint8 reserved[9];
}
现在EFS文件大小为16字节,所以我认为它是打包的。
现在我有相同的结构,在上电时我从EFS读取值,但我的编译器返回的结构的大小为18字节(编译器不支持打包,因此EFS读取失败) )。
我只读了16个字节并且它通过了。
问题:
(1)。如果我只读取16个字节,则不存在数据丢失的风险,因为在第一个成员之后,我的结构中将有一个字节填充空间(因为我的编译器不支持Packed结构而我不能使用它) 我将以下值写入EFS,
version -0
y1 -6
y2 -10
y3 -60
我只读了16个字节,并且我的结构的每个成员都分配了正确的值。是否存在我的结构将具有错误值的任何情况。
(2)。由于第一步的混淆,我创建了一个临时结构,如下面
struct
{
uint8 version;
uint8 y1_a;
uint8 y1_b;
uint8 y2_a;
uint8 y2_b;
uint8 y3_a;
uint8 y3_b;
uint8 reserved[9];
}
现在EFS和结构大小都是16字节, 现在,当我将输入提供给EFS时 version = 0,y1 = 6,y2 = 10,y3 = 60,
为成员分配如下值:version = 0,y1_a = 6,y1_b = 0,y2_a = 10,y2_b = 0, y3_a = 60,y3_b = 0;
有人可以帮助理解这个吗? 我的想法是读取临时结构(以便EF和我的结构的大小都相同),然后从temp struture为我的原始结构赋值
答案 0 :(得分:0)
我假设您只是通过将EFS中的字节复制到结构来读取数据。
(如果你填写这样的结构:
read(&(s.version)...);
read(&(s.y1)...);
当然,你对打包或解压缩的结构没有任何问题......但是你必须确保以相同的方式完成写作。)
根据编译器的不同,EFS读取的数据肯定无法正确分配。
为了检查编译器如何完成打包,我会做两个测试:
int a = ((int)&(s.y1)) - ((int)&(s.version));
如果编译器打包,则为1,否则为2。
union {
struct {
uint8 version;
uint16 y1;
...
} unsure;
struct {
uint8 version;
uint8 y1_a;
uint8 y1_b;
...
} definitely_unpacked;
}
这个联合应该让你更详细地了解正在发生的事情:当你将数据读入联合时,你可以看到第二个结构中的哪个uint8将映射到第一个结构中的哪个uint16。