小智..
12
答案肯定是特定于实现的.要明确找到您的平台/编译器,只需在代码中的某处添加此输出:
printf ("sizeof time_t is: %d\n", sizeof(time_t));
如果答案是4(32位)并且您的数据要超过2038,那么您有25年的时间来迁移代码.
如果您将数据存储为字符串,那么您的数据就可以了,即使它很简单:
FILE *stream = [stream file pointer that you've opened correctly];
fprintf (stream, "%d\n", (int)time_t);
然后以同样的方式读回它(fread,fscanf等等到int中),你就有了你的纪元偏移时间..Net中存在类似的解决方法.我在Win和Linux系统之间传递64位纪元数字没有问题(通过通信渠道).这带来了字节排序问题,但这是另一个主题.
要回答paxdiablo的查询,我会说,它印有"19100",因为该计划是这样写的(我承认我这样做是在80年代我自己):
time_t now;
struct tm local_date_time;
now = time(NULL);
// convert, then copy internal object to our object
memcpy (&local_date_time, localtime(&now), sizeof(local_date_time));
printf ("Year is: 19%02d\n", local_date_time.tm_year);
该printf语句打印固定字符串"Year is:19",后跟一个零填充字符串,其中包含"1900年以来的年份"(定义tm->tm_year).在2000年,这个值显然是100."%02d"垫有两个零,但如果长度超过两位则不截断.
正确的方法是(仅改为最后一行):
printf ("Year is: %d\n", local_date_time.tm_year + 1900);
新问题:这种想法的基本原理是什么?