如果一个工程之前是用VC6编译的,对CTime对象直接串行化,此时的CTime对象时32位的数据;现在改用VS2008编译,串行化读取CTime对象时,读取的是64位数据。这样造成了后续数据的读取错误。
请问,有没有好的方法,让VS2008下的CTime仍当作32位数据,或者通过其它方式来处理这样的CTime问题?
谢谢
请问,有没有好的方法,让VS2008下的CTime仍当作32位数据,或者通过其它方式来处理这样的CTime问题?
谢谢
解决方案 »
- 关于Windows media player中如何实现单曲循环播放?
- 为什么明明在MFC对话框属性里,设置了不要标题栏,运行时还是有!!!
- 在MainFrame中用create方法创建一个非模态对话不能响应控件消息,上面的按钮连点都点不动?
- 请问一个关于通信方面字符编码的问题?
- activemovie在播放视频文件时,如何判断该视频文件已播放完毕?
- 怎么样判断一个DLL是COM组件?
- 请问我在打开vc的对话框时,会提示"the file has been modified outside of the source editor.do you want reload it"?
- 一个简单的问题,请高手指教(在线等待)!
- 如何根据一个进程的名称得到进程的ID和HANDLE啊?
- VS2010 静态库依赖问题
- MFC触发信号问题
- 多线程问题,请明白人进来看看,帮我解释一下代码~
我用VS2008都是32位的。
__time64_t time //2008
) throw( );把time_t改成__time64_t
现在,我2008编译的程序要打开用VC6的编译的程序串行化的数据,由于2008编译的程序读老程序串行的数据时,多读了数据,这样就出现了不兼容问题
CTime time(__time32_t t); 后来仔细定位了一下,发现微软升级CTime到64位时,做了兼容处理,那就是串行化读取VC6编译的CTime对象时,先读取32位(4字节)数据,如果该数据有效,按此32位数据直接串行化处理,如果是无效的特殊值,则再读取64位(8字节)数据,按新版CTime对象串行化。所以新版本可以读取旧版本保存的文件,但是旧版本不能读取新版本保存的文件。注意:这个串行化是用(<<, >>)来实现的。