我有一个带有以下并集的C ++库:
typedef union DVersion
{
uint32_t VMask;
struct
{
uint8_t Build;
uint8_t Rev;
uint8_t Min;
uint8_t Maj;
};
}DATA_VER;
还有另一种结构,其字段包含此结构
typedef struct DH
{
uint16_t Tok1;
DATA_VER DVersion;
uint16_t DataCount;
}DataHeader
当我在C ++上使用此dll时,它也可以在C#上完美运行。因此,DLL已通过验证。
当我使用ctypes处理Python时,看起来字节的数量不对应。
我已经尝试过这些解决方案
解决方案1:
class VER_Struct(Structure):
_fields_ = [("Build", c_uint8),
("Rev", c_uint8),
("Min", c_uint8),
("Maj", c_uint8)]
class DATA_VER(Union):
_anonymous_ = ("u",)
_fields_ = [("VMask", c_uint32, 32),
("u",VER_Struct)]
class DataHeader(Structure):
_fields_ = [("Tok1", c_uint16, 16),
("DVersion", DATA_VER),
("DataCount", c_uint16, 16)]
解决方案2:
class DATA_VER(Union):
_fields_ = [("VMask", c_uint32, 32),
("Build", c_uint8),
("Rev", c_uint8),
("Min", c_uint8),
("Maj", c_uint8)]
class DataHeader(Structure):
_fields_ = [("Tok1", c_uint16, 16),
("DVersion", DATA_VER),
("DataCount", c_uint16, 16)]
在两种情况下,Tok1都具有正确的值,但是DVersion和DataCount不能正确显示。在我看来,由于嵌套结构,字节未对齐。
您能提示我我在做什么错吗?非常感谢您!
答案 0 :(得分:1)
我发现了!
即使在ctypes文档中没有明确规定,也应包括在内
_pack_ = 1
在您的结构上。就我而言,是:
class VER_Struct(Structure):
_fields_ = [("Build", c_uint8),
("Rev", c_uint8),
("Min", c_uint8),
("Maj", c_uint8)]
class DATA_VER(Union):
_anonymous_ = ("u",)
_fields_ = [("VMask", c_uint32, 32),
("u",VER_Struct)]
class DataHeader(Structure):
_pack_ = 1
_fields_ = [("Tok1", c_uint16, 16),
("DVersion", DATA_VER),
("DataCount", c_uint16, 16)]
希望这对其他人有帮助!