3

我有一个定义为的数据结构

struct myDataStruct
{
   int32_t header;
   int16_t data[8];
}

我想获取一个字符流并将其转换为 myData 流。我应该扩展什么流类?我想创建一个自定义流类,以便我可以做类似的事情

myDataStruct myData;
myDataStruct myDataArray[10];

myDataStream(ifstream("mydatafile.dat"));
myDataStream.get(myData);
myDataStream.read(myDataArray, 10);
4

2 回答 2

5

而不是myDataStream.get(myData),您所做的是重载operator>>您的数据类型:

std::istream& operator>>(std::istream& is, myDataStruct& obj)
{
  // read from is into obj
  return is;
}

如果要读入数组,只需编写一个循环:

for( std::size_t idx=0; idx<10; ++idx ) 
{
   myDataStruct tmp;
   if( is >> tmp )
     myDataArray[idx] = tmp;
   else
     throw "input stream broken!";
}

使用函数模板,您还应该能够重载右侧数组的运算符(但我从未尝试过):

template< std::size_t N >
std::istream& operator>>(std::istream& is, myDataStruct (&myDataArray)[N])
{
  // use loop as above, using N instead of the 10
}

但我无法决定这是华丽还是卑鄙。

于 2009-08-31T22:50:08.697 回答
0

如果您使用的是未格式化的输入,您可能应该直接以二进制形式阅读。通常你会使用一些编译器特定的指令来创建没有填充的数据结构,然后从文件中读取/写入。

// Gcc
#pragma pack(1) // option 1: pragmas
struct frame {
   std::uint32_t header;
   std::uint16_t data[8];
} __attribute((packed)); // option 2: packed attribute
#pragma pack(0)

bool operator==( data const & lhs, data const & rhs )
{
   bool result = lhs.header == rhs.header;
   for ( int i = 0; i < 8; ++i )
   {
      result &= lhs.data[i] == rhs.data[i];
   }
   return result;
}

int main()
{
   frame data = { 10, 1, 2, 3, 4, 5, 6, 7, 8 };

   std::ofstream out( "data.bin", ofstream::binary );
   out.write( reinterpret_cast<char*>(&data), sizeof(data) );
   out.close();

   std::ifstream in( "data.bin", ifstream::binary );
   frame readed;
   in.read( reinterpret_cast<char*>(&readed), sizeof(readed) );
   in.close();

   std::cout << (readed == data) << std::endl; // 1
}

禁用 VS 填充的编译器指令可能不同(我相信 pragma 指令在 gcc 和 VS 中都有效,但我一直使用该属性)。

于 2009-09-01T09:33:08.873 回答