0

我创建了一个 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 字节,是否存在数据丢失的风险,因为在第一个成员之后,我的结构中会有一个字节填充空间(因为我的编译器不支持打包结构,我不能使用它)我写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 的输入作为版本 =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 的大小和我的结构都相同),然后从临时结构中为我的原始结构分配值

4

1 回答 1

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。

于 2013-08-24T05:40:59.187 回答