几组神奇的日期
1899-12-31 # 在 VB 中,其所有日期函数的基准日 (第0天) 是 1899年12月30日 (星期六),第一天就是 1899年12月31日 (星期日)
1900-01-01 # xls 日期基数日(第1天)
## =DATEVALUE("1900/1/1")
结果:
比如:
44725,就是我们离“1900/01/01”一共经过了44725天
1970-01-01 1970年1月1日0点也就被称为计算机元年
时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。
# 很多编程语言起源于UNIX系统,而UNIX系统认为1970年1月1日0点是时间纪元,所以为偶们常说的UNIX时间戳是以1970年1月1日0点为计时起点时间的。
深入的了解
最初计算机操作系统是32位,而时间也是32为表示。
System.out.println(Integer.MAX_VALUE); 2147483647
Integer在java内用32位表示,因此32为能表示的最大值就是2147483647。另外一年365天的总秒数是31536000,2147483647/31536000=68.1,也就是说32为能表示的最长时间是68.1,也就是说32为能表示的最长时间就是68年,从1970年开始的话,加上68.1年,实际最终到2038年01月19日03时14分07秒,便会达到最大时间,过了这个时间点,所有32为操作系统时间便会变为10000000 00000000 00000000 00000000,算下来也就是1901年12月13日20时45分52秒,这样便会出现时间回归的现象,很多软件便会运行异常。
到这里我想问题的答案已经显现出来了,那就是因为用32为来表示时间的最大间隔是68年,而最早出现的UNIX系统考虑到计算机产生的年代个应用的时限,综合取了1970年1月1日作为UNIX TIME的纪元时间(开始时间),至于时间回归现象相信随着64位操作系统可以表示到292,277,026,596年的12月4日14时30分08秒,这是时间已经是千亿年以后了,所以也不用担心了。
参考:
https://blog.csdn.net/Ayca1/article/details/107115386/
相关文章
- Sql日期时间格式转换
- Excel显示当前日期
- SQL 横转竖 、竖专横 (转载) 使用Dapper.Contrib 开发.net core程序,兼容多种数据库 C# 读取PDF多级书签 Json.net日期格式化设置 ASPNET 下载共享文件 ASPNET 文件批量下载 递归,循环,尾递归 利用IDisposable接口构建包含非托管资源对象 《.NET 进阶指南》读书笔记2------定义不可改变类型
- iview的table组件中加入超链接组件,可编辑组件,选择组件,日期组件
- LigerUi弹出编辑窗口中日期默认当前日期设设置!
- java web中日期Date类型在页面中格式化显示的三种方式
- easyui datebox定位到某一个日期, easyui datebox直接定位到具体的日期, easyui datebox MoveTo方法使用
- Python数据处理Tips日期、时间数据处理方法汇总
- SwiftUI实战之如何显示中文日期选择器datepicker
- 4.有关日期格式属性改动常识,v$nls_parameters,between and,查询指定部门的员工信息,in和null,like模糊查询,order by后面能够跟:列名、表达式、别名、序号
- nyoj 75-日期计算 (闰年与平年的判断)
- iOS - 获取系统时间年月日,阳历(公历)日期转农历的方法
- CRMEB 日期
- Mysql 中的日期时间函数汇总
- mysql 日期转换sql函数