有一个二进制文件 1.bin 存有多条记录,每条包含若干内容,每条记录长度一定。
我为了读出这些记录,定义了一个结构:
typedef struct 
{
    u_char Name[40];     
    u_char Status;
    u_char Comm_Port;
    u_char Sync_Async_Flag;
    u_char Lru;
    u_char Io_Status;
    u_short Pnt_Number[5];
    long Pnt_Handle[MAX_PNT_TYPE];
    u_long Total_Comm_Cnt;
    u_long Start_Comm_Time;
    u_long Comm_Lost_Sync_Cnt;
    u_long Comm_Crc_Error_Cnt;
    float Comm_Statistics;
    u_long Comm_Correct_Cnt;
    float Comm_Alarm_Limit;
    float Comm_Alarm_Deadband;
    u_char Comm_Alarm_Ack;
    u_char Comm_Alarm_Type;
    u_short Swt_Chg_Cnt_Idx; 
    u_char Fail_Alarm_Hbt;  
    u_char Alarm_Hbt;
    u_char Print_Hbt;
    u_char Rtu_Type;
    u_char Stn_Spare;
    u_char Stn_Enable;
    u_char Async_Trans_Protocol_Ndx;
    u_char Slot_Type[MAX_SLOT_PER_LRU];
    u_char Stn_Lru_Status;
    u_char Reserved[39];
} stndef;使用_lread函数读
 _lread(hfp, (stndef *)&stn_pnt, sizeof(stndef)) != sizeof(stndef)
按我理解文件1.bin 的第46和47字节应作为u_short型读入Pnt_Number[0],但实际是第47和48字节作为u_short型被读入Pnt_Number[0],而文件1.bin 不能改变。怎么才能正确的读出来

解决方案 »

  1.   

    这样子试一下
    #pragma pack(push) //保存对齐状态
    #pragma pack(1)
    typedef struct 
    {
        u_char Name[40];     
        u_char Status;
        u_char Comm_Port;
        u_char Sync_Async_Flag;
        u_char Lru;
        u_char Io_Status;
        u_short Pnt_Number[5];
        long Pnt_Handle[MAX_PNT_TYPE];
        u_long Total_Comm_Cnt;
        u_long Start_Comm_Time;
        u_long Comm_Lost_Sync_Cnt;
        u_long Comm_Crc_Error_Cnt;
        float Comm_Statistics;
        u_long Comm_Correct_Cnt;
        float Comm_Alarm_Limit;
        float Comm_Alarm_Deadband;
        u_char Comm_Alarm_Ack;
        u_char Comm_Alarm_Type;
        u_short Swt_Chg_Cnt_Idx; 
        u_char Fail_Alarm_Hbt;  
        u_char Alarm_Hbt;
        u_char Print_Hbt;
        u_char Rtu_Type;
        u_char Stn_Spare;
        u_char Stn_Enable;
        u_char Async_Trans_Protocol_Ndx;
        u_char Slot_Type[MAX_SLOT_PER_LRU];
        u_char Stn_Lru_Status;
        u_char Reserved[39];
    } stndef;
    #pragma pack(pop)
      

  2.   

    在结构中,编译器为结构的每个成员按其自然对界(alignment)条件分配空间;各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同。在缺省情况下,C编译器为每一个变量或是数据单元按其自然对界条件分配空间例如,下面的结构各成员空间分配情况struct test {
    char x1;
    short x2;
    float x3;
    char x4;
    };
      
                     
      结构的第一个成员x1,其偏移地址为0,占据了第1个字节。第二个成员x2为short类型,其起始地址必须2字节对界,因此,编译器在x2和x1之间填充了一个空字节。结构的第三个成员x3和第四个成员x4恰好落在其自然对界地址上,在它们前面不需要额外的填充字节。在test结构中,成员x3要求4字节对界,是该结构所有成员中要求的最大对界单元,因而test结构的自然对界条件为4字节,编译器在成员x4后面填充了3个空字节。整个结构所占据空间为12字节。现在你知道怎么回事了吧?更改C编译器的缺省分配策略
      一般地,可以通过下面的两种方法改变缺省的对界条件:
      · 使用伪指令#pragma pack ([n])
      · 在编译时使用命令行参数
    #pragma pack ([n])伪指令允许你选择编译器为数据分配空间所采取的对界策略   
                   
      
      例如,在使用了#pragma pack (1)伪指令后,test结构各成员的空间分配情况就是按照一个字节对齐了
      #pragma pack(push) //保存对齐状态
    #pragma pack(1)
    #pragma pack(pop)