部分普通旧数据

Partial plain old data

本文关键字:数据      更新时间:2023-10-16

关于POD的很多问题;但所有问题都是关于完整对象复制的。我可以将相同的概念应用于类的普通旧数据部分吗?例子:

struct Parent1
{
    int x;
    float y;
};
struct Parent2
{
    int k;
    float l;
};
struct NotPod : public Parent1, public Parent2
{
    char z;
    short w;
};
NotPod a, b;
void func()
{
    a.z = '4';
    a.w = 345;
    memcpy((char*)&b.z, (char*)&a.z, (char*)(&a.w)-(&a.z) + sizeof(a.w));
}

我问的是旧的c++(不是c++ 11)。

我从您的示例代码中了解到,您的问题不是关于pod的。您需要的是保证大多数派生类的成员是聚合的,并且它们具有连续的内存布局。

见9.2.12 (ISO 14882:2003)

分配没有中间访问说明符的(非联合)类的非静态数据成员以便以后的成员在类对象中拥有更高的地址。非静态的分配顺序由访问说明符分隔的数据成员未指定(11.1)。

简单地说,不要把public/protected/private访问说明符放在聚合序列之间,你就会得到这样的保证。

所以您只想复制结构体中Parent部分的成员。如果是,为什么不实现像func3()?

void func2()
{
    a.z = '7';
    a.w = 444;
    a.x = 4;
    a.y = 2.1;
    memcpy(&b, &a, sizeof(NotPod)); // copies all the members
}
void func3()
{  
    a.z = '7';
    a.w = 444;
    a.x = 4;
    a.y = 2.1;
    memcpy(&b, &a, sizeof(Parent)); // copies only the members of the Parent
}

正如您自己所说,它不是c++ 03中的POD。它的一部分是(Parent1和Parent2),但您希望将其余部分视为POD。好吧,那就把剩下的都做成POD吧。通过定义一个局部结构体

struct NotPod : public Parent1, public Parent2
{
    struct InternalPod
    {
       char z;
       short w;
    };
    InternalPod i; 
};

或从第三个结构体继承:

struct InternalPod
{
   char z;
   short w;
};
struct NotPod : public Parent1, public Parent2, public InternalPod
{
};