php时间日期处理到2038年之后该怎么办?
- linux arm板启动时间同步服务 推荐度:
- XP系统启动时滚动条总是时间很长 推荐度:
- javascript - Server-Side Paging with MySQL, PHP, and AngularJS - Stack Overflow 推荐度:
- Unified coding style for Javascript, PHP, C, and C++ - Stack Overflow 推荐度:
- javascript - determine if a restaurant is open now (like yelp does) using database, php, js - Stack Overflow 推荐度:
- 相关推荐
也是无意之间发现的一个问题,因为php的时间处理使用UNIX时间戳,也就是他能够表示的日期范围是1970 年 1 月 1 日到 2038 年 1 月 19 日,那么超过这个范围怎么办呢?比如2039年?
网上搜罗的解决方案大多是:
1.不用担心,到2038年之后你的系统都不知道升级多少次了,那个时候肯定有解决办法。
2.php是开源的,你们可以修改代码重新编译
3.使用DateTime类。。。
4.使用64位操作系统
个人觉得使用64位操作系统还是比较根本的解决办法。于是测试了下windows 7 64bit安装wamp测试,代码如下:
<?php
$time = strtotime('2099-10-1');
echo $time . '<br>';
echo date("Y-m-d",$time);
?>
结果输出:1970-1-1
难道64位系统不能解决该问题?
于是,将刚才的代码放到一台centos 6.6 x64操作系统,php5.3环境的云服务器上再次测试运行,输出下面的结果:
4094467200
2099-10-1
什么?你觉得不过瘾?9999年?,好,我们来试一下,将上面的代码修改一下
<?php
$time = strtotime('9999-12-31');
echo $time . '<br>';
echo date("Y-m-d",$time);
?>
还是centos 6.6 x64版本+php5.3的环境,运行,输出结果如下:
253402185600
9999-12-31
应该够用了,64位操作系统可以表示到292,277,026,596年12月4日15时30分08秒,而那个时候地球还在不在,已经不知道了。
纠结了好久的问题,终于还是不算啥问题。
最新文章
- 360进军搜索,全站推自主搜索引擎
- Google正在测试最新升级的句法搜索功能
- Windows位图文件格式[转]
- 4. 串的【朴素模式匹配算法】、【KPM算法:求next数组、nextval数组】
- 栅栏密码(The Rail
- 信号完整性
- Eolink如何解决API测试痛点
- Linux Crontab执行hadoop命令脚本失败
- 箱型图盒图 jupyter Notebook
- JMS(Java Messaging Service)基础
- 高并发部署策略 多副本服务+nginx均衡负载
- js callee与caller 区别
- Caused by: com.alibaba.nacos.shaded.io.grpc.netty.shaded.io.netty.channel.AbstractChannel$AnnotatedC
- window安装Linux
- pageInfo的转化,do转vo
- 数电和Verilog
- call和calling的用法