C/C++中的非固定结构

Unfixed structure in C/C++

本文关键字:结构 C++      更新时间:2023-10-16

我有一个名为TOWRITE的结构。我想把内容和结构写进一个文件。但有一点是,结构构件的尺寸是不固定的。它取决于从另一个来源接收到的数据。有可能用简单的方法写出结构吗。请参阅下面的代码片段。

感谢

typedef struct TOWRITE
{
   DWORD dwHeader;
   WORD datacount;
   LPBYTE lpData;
   WORD checksum;
}
TOWRITE towrite;
ZeroMemory( &towrite, sizeof( TOWRITE ));
towrite.lpData = (LPBYTE) new BYTE[256];
towrite.dwHeader = 0xF1F1E1E1;
towrite.datacount = 256;
towrite.cheksum = 3849;
CopyMemory( towrite.lpData, szTemp, 256 );
.....
.....
.....
f.write( (LPBYTE)&towrite, sizeof(TOWRITE) );
....
....
....
....
typedef struct TOWRITE
{
   DWORD dwHeader;
   WORD datacount;
   WORD checksum;
   LPBYTE lpData; //Put the ptr at the end
}
// - sizeof(LPBYTE) avoid the ptr @ to be written
f.write( (LPBYTE)&towrite, sizeof(TOWRITE) - sizeof(LPBYTE));  
// write the ptr data.
// sorry I don't know windows C.
// fix the size of the array element :)
f.write( towrite.lpData, towrite.datacount * sizeof(????));  

您可以尝试tpl库:http://tpl.sourceforge.net/

Tpl是一个用于序列化C数据的库。数据以其自然的二进制形式存储。API很小,并试图"置身事外"。与使用XML相比,tpl在C程序中使用起来更快、更容易。Tpl可以序列化许多C数据类型,包括结构。

有可能用简单的方法写出结构吗。

我不能使用任何外部库

那么没有。无论是C的TPL还是C++的优秀Boost.Serialization,库都是的简单方法。C和C++没有用于序列化数据结构的内置机制。因此,如果您不能使用库,那么您将不得不自己编写序列化代码。

只使用两个写调用:

f.write ((LPBYTE)&towrite, sizeof(TOWRITE));
f.write ((LPBYTE)&towrite.lpData, towrite.datacount * sizeof(BYTE));

然后你可以用再次阅读

TOWRITE towrite;
f.read ((LPBYTE)&towrite, sizeof(TOWRITE));
towrite.lpData = (LPBYTE) new BYTE[towrite.datacount];
f.read ((LPBYTE)&towrite.lpData, towrite.datacount * sizeof(BYTE));

使用这种方法可以避免由于结构填充而产生的冗余数据。

char* data =malloc(sizeof(towrite)-sizeof(LPBYTE)+var_data);
CopyMemory( data, towrite.dwHeader, sizeof(DWORD) );
CopyMemory( data, towrite.datacount, sizeof(WORD) );
CopyMemory( data, szTemp, datalength);
CopyMemory( data, towrite.checksum, sizeof(WORD) );
f.write( data,sizeof(towrite)-sizeof(LPBYTE)+var_data);

我刚刚将代码修改为

typedef struct TOWRITE
{
 DWORD dwHeader;
 WORD datacount;
}
TOWRITE towrite;
LPBYTE lpData;
WORD checksum;
ZeroMemory( &towrite, sizeof( TOWRITE ));
lpData = (LPBYTE) new BYTE[256];
towrite.dwHeader = 0xF1F1E1E1;
towrite.datacount = 256;
cheksum = 3849;
CopyMemory( lpData, szTemp, 256 );
.....
.....
.....
f.write( (LPBYTE)&towrite, sizeof(TOWRITE) );
f.write( (LPBYTE)&lpData, datacount );
f.write( (LPBYTE)&checksum, 2 );
....
....
....
....