结构体存储文件 C 深入理解2 直接存储,有大端和端的问题。

struct st
{
    char  a;
    char  b;
    char  e;
    int   d;
    char* p;
};    
class Cst
{
    private:
    int a;
    int b;
    
    public:
        Cst(int a,int b):a(a),b(b) { }
        Cst() { }
      virtual void print() { cout<<a<<b<<endl;} 
      char* name;
};    
int main()
{
    
    Cst ss('A','B');
    ss.print();
    ss.name = "test";
    int* ptr =reinterpret_cast<int*>(&ss);
    printf("%0x\n",*ptr);
    printf("%p\n",ptr);
    FILE* pFile = fopen("G:\\st.txt","w");  
    if(pFile == NULL) cout<<"error"<<endl;
    fwrite(&ss,sizeof(ss),1,pFile);   
    fclose(pFile);
    system("pause");
    return 0;
}        
打印结果:
12
6566
4360d0
0022FF20
请按任意键继续. . .

文件中存储的信息。    
我们来分析下,所谓的直接写对象到文件中是怎么个原理   首先明白X86是小端
首先对象开始4个空间放的是虚表的指针 0x004360d0  你发现了没,和存储文件上面2进制序列大小端刚好相反。那是因为C语言打印函数肯定将内存中小端还原成我们熟悉的序列打印的。但是fwrite直接写入,便是内存中一个连续范围内数值的copy当然不会管你什么大小端。因此就造成上面文本的效果。
当我们fread时候,之间见上面2进制copy到内存连续空间,当然也是小端,刚好符合X86小端。因而不存在任何问题。
但是要是不同系统之间呢,小端和大端之间。这个问题就比较严重了。
可见,直接将对象写入文件是很不好的一种选择。当对象中有指针,我们只能写入指针变量内指向的地址。这个也是我们不能接受的。
为了解决上面问题,我们就提出了序列化的概念。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值