如果一个工程之前是用VC6编译的,对CTime对象直接串行化,此时的CTime对象时32位的数据;现在改用VS2008编译,串行化读取CTime对象时,读取的是64位数据。这样造成了后续数据的读取错误。
请问,有没有好的方法,让VS2008下的CTime仍当作32位数据,或者通过其它方式来处理这样的CTime问题?
谢谢

解决方案 »

  1.   

    VS2008下面读取的是64位数据吗,你确定。
    我用VS2008都是32位的。
      

  2.   

    In Visual C++ versions 6.0 and earlier, time was a value of time_t. Visual C++ .NET and later converts a time_t parameter to __time64_t. CTime(
       __time64_t time   //2008
    ) throw( );把time_t改成__time64_t
      

  3.   

    我知道CTime::m_time是有__time64_t(即__int64)定义的
    现在,我2008编译的程序要打开用VC6的编译的程序串行化的数据,由于2008编译的程序读老程序串行的数据时,多读了数据,这样就出现了不兼容问题
      

  4.   

    CTime time(__time32_t t); 试试这个,强行指定用32位的
      

  5.   

    我也遇到这个问题,google到这个帖子。这个结论可行吗?我怎么觉得新版CTime没有这个构造函数啊?
    CTime time(__time32_t t); 后来仔细定位了一下,发现微软升级CTime到64位时,做了兼容处理,那就是串行化读取VC6编译的CTime对象时,先读取32位(4字节)数据,如果该数据有效,按此32位数据直接串行化处理,如果是无效的特殊值,则再读取64位(8字节)数据,按新版CTime对象串行化。所以新版本可以读取旧版本保存的文件,但是旧版本不能读取新版本保存的文件。注意:这个串行化是用(<<, >>)来实现的。