2019-03-06 C++二进制文件结构体读取问题

C与C++的二进制文件读写

参考下面的文章,C/C++读写文本文件、二进制文件

https://blog.csdn.net/nichengwuxiao/article/details/78789225

C的文件操作

#include <stdio.h>
ephDE_recOne rec;                           // 结构定义
FILE * f = fopen("file_name","rb");         // 文件打开
if(f == NULL)  return;                      // 打开失败
fread(&rec, sizeof(ephDE_recOne),1, f);     // 读二进制文件数据
fclose(f);

C++的文件操作

#include <iostream>
#include <fstream>
ephDE_recOne rec;                                     // 结构定义
ifstream infile("file_name",ios::in | ios::binary);   // 文件打开
if(!infile)  return;                                  // 打开失败
infile.read((char *)&rec, sizeof(double)*deLen);      // 读二进制文件数据
infile.close();

C++的二进制文件读取结构体问题

在编写一个DE405星历文件的读取函数中,结构体读取后数值与实际的不一致。
在下面这段代码中,读取struct后labelconstName内容正确,后面结构数值不正确。

struct ephDE_recOne{
    char    label[3][84];
    char    constName[400][6];
    double  timeData[3];
    int     numConst;
    double  AU;
    double  EMRAT;
    int     coeffPtr[12][3];
    int     DENUM;
    int     libratPtr[3];
    int     RSize;
};
const int deLen = 1018;
void read(){
    using namespace std;
    ephDE_recOne rec;
    ifstream infile(DE_file_path.c_str(), ios::in | ios::binary);
    if(!infile)
        throw exception();
    infile.read((char *)&rec, sizeof(double)*deLen);
    infile.close();
}    

通过比较读取结果与实际数值发现,读取到的AU数值为实际的EMRAT数值。因此猜测是数据结构体的发生了错位情况。

代码编译的字节对齐问题 #pragma pack(push,1)

由于不是专业出身,这个内存字节的原因不能说清楚。原来在用fortran编写带有通信接口的程序时曾遇到过类似问题,虽然代码不做改动,但是否指定单字节内存对齐将影响数据处理的结果。
这里,我使用的是Qt的mingw32编译套件编译的程序,将上述代码的结构定义修改为

#pragma pack(push, 1)
struct ephDE_recOne{
    char    label[3][84];
    char    constName[400][6];
    double  timeData[3];
    int     numConst;
    double  AU;
    double  EMRAT;
    int     coeffPtr[12][3];
    int     DENUM;
    int     libratPtr[3];
    int     RSize;
};
#pragma pack(pop)

二进制文件的数据结构能够正确读写。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容