为什么编程语言以及数据库要从1970年1月1日开始计算时

最初计算机操作系统是32位,而时间也是用32位表示。

System.out.println(Integer.MAX_VALUE);
2147483647



IntegerJAVA内用32位表示,因此32位能表示的最大值是2147483647。另外1365天的总秒数是31536000,

2147483647/31536000 = 68.1

也就是说32位能表示的最长时间是68年,而实际上到20380119031407
秒,便会到达最大时间,过了这个时间点,所有32位操作系统时间便会变为
10000000 00000000 00000000 00000000

也就是19011213204552秒,这样便会出现时间回归的现象,很多软件便会运行异常了。

到这里,我想问题的答案已经出来了:

因为用32位来表示时间的最大间隔是68年,而最早出现的UNIX操作系统考虑到计算
机产生的年代和应用的时限综合取了
197011日作为UNIX TIME的纪元时间(开始
时间
),而java自然也遵循了这一约束。

至于时间回归的现象相信随着64为操作系统的产生逐渐得到解决,因为用64位操作
系统可以表示到
292,277,026,596124153008秒,相信我们的N代子孙,哪
怕地球毁灭那天都不用愁不够用了,因为这个时间已经是千亿年以后了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/548503.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入了解EntityFramework——Lazy Loading与Eager Loading

Lazy Loading:延迟加载。Eager Loading:贪婪加载。 首先通过一个简单的控制台应用程序例子说明延迟加载: 订单主表和订单从表,并且订单主表和订单从表是一对多的关系,代码如下图所示: //订单主表public cl…

SQL – 2.SQLServer的管理 + 3.SQL基础1 + 4.SQL基础2

SQLServer的管理 常用字段类型:bit(可选值0、1)、datetime、int、varchar、nvarchar(可能含有中文用nvarchar)varchar、nvarchar 和char(n)的区别: char(n)不足长度n的部分用空格填充。Var:Variable,可变的…

EntityFramework进阶——继承

通过类型继承,我们可以更弹性地处理数据,有3中相关的技巧,即TPH,TPT,TPC。 Table Per Hierarchy(TPH) 当单个数据表存储不同数据类型时,在数据模型的设计上,可以使用Tab…

几种Lucene.Net打开IndexReader的方式

入门第一式: IndexReader.Open(Dir,readOnly); 当readOnly为true的时候效率最高,最好不要用Reader删除修改记录; 入门第二式: reader.Reopen(readOnly); 优点:比第一式效率高,推荐使用; 缺点&am…

EntityFramework进阶——数据编辑与维护

实体数据对象状态 在EF环境下,应用程序更改数据对象会引发数据集状态的变更,可能的状态有以下几种: 数据对象状态列表Added添加实体对象创建到实体集中,数据未添加进数据库Modified实体对象已经存在于实体数据集中,数…

第六章扩展——VMA

由 user process角度来说明的话,VMA 是 user process 里一段 virtual address space 区域;virtual address space 是连续的内存空间,当然VMA 也会是连续的空间。VMA 对 Linux 的主要好处是,可以内存的使用更有效率,並且…

EntityFramework进阶——数据变更冲突

TimeStamp 更新操作可能伴随数据冲突,我们可以通过并发处理妥善解决这一方面的问题。避免数据冲突比较方便的做法是自动加入字节数组(byte[])类型的TimeStamp属性,对应到数据表中的rowvewsion类型字段,自动监控数据的…

MyBatis 数据持久层

引用:http://baike.baidu.com/view/4372646.htm MyBatis 的前身就是 iBatis 。是一个数据持久层(ORM)框架。 MyBatis框架 [1]iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Ac…

EntityFramework进阶——事务

事务处理 EF支持事务处理操作,以下语句会获取当前DbContext对象专用的DbContextTransaction事务处理的对象: DbContextTransaction transaction context.Database.BeginTransaction() 获取transaction之后,期间任何与context有关的数据均…

TP类库解析和使用系列[Input类]

2019独角兽企业重金招聘Python工程师标准>>> [ 概述 ] Input类是新版新增的一个输入数据管理类,提供了一些输入数据的管理和过滤。 [ 方法 ] getInstance 实例化Input类 filter 设置数据过滤方法 以下方法都是动态方法: get 获取get数据 post…

简单描述char(n)、varchar(n)、nchar(n)、nvarchar(n)的区别

它们的区别概括成: char,nchar :定长,速度快,占空间大,需处理 varchar,nvarchar :不定长,空间小,速度慢,无需处理 nchar、nvarchar:处…

详解CSMA/CD

学网络的人,恐怕都得知道在总线网络中必须要用到CSMA/CD来传输数据。 CSMA/CD——带冲突检测的载波侦听多路访问机制,用来决定某一时刻介质访问权限问题,原理如下:所有站点共享一条传输线路(总线)&…

SqlServer中dateTime、dateTime2、date、datetimeoffset的区别

date 存入的数据格式为:yyyy-mm-dd datetime 存入的数据格式为:yyyy-mm-dd hh:mm:ss.fff(精确到1毫秒) datetime2 存入的数据格式为:yyyy-mm-dd hh:mm:ss.fffffff(精确到0.1微秒) datetimeoffset 存入的数据格式为&…

php读取checkbox数组值

2019独角兽企业重金招聘Python工程师标准>>> 用在批量删除或者更新等操作方面 <form method"post" action"CheckAction.php"> <input type"checkbox" value"h" name"flags[]">头条[h] <input ty…

EntityFramework进阶——Entity Splitting和Table Splitting

Entity Splitting——把单个实体拆分成多个表。Table Splitting——把单个表拆分成多个实体 Entity Splitting 下面通过例子来说明&#xff1a; 假设存在如下实体类&#xff1a; public class Employee{public int EmployeeId { get; set; }public string Name { get; set; …

[转]android webview学习

本文转自&#xff1a;http://hi.baidu.com/relayon/blog/item/92b15463677d3e6b0d33fa79.html 在移动互联网的争夺日趋白热化&#xff0c;各个互联网巨头纷纷推出自己的手机浏览器&#xff0c;浏览器市场的争夺从桌面转移到了手机。在Android手机中内置了一款高性能webkit内核浏…

EntityFramework进阶——CodeFirst数据库迁移

与视觉操作界面相比&#xff0c;CodeFirst机制提供了一套命令行模式的迁移工具&#xff0c;协助开发人员有效的进行数据库与数据模型的同步维护操作。 新建一个控制台项目CFMigrationsDemo&#xff0c;选用来自数据库的EF设计器模式&#xff0c; 并向其中添加一个Product.cs类文…

java远程debug

常常会遇到在应用部署在weblogic,tomcat,jetty等服务器下&#xff0c;而我们的代码却在本地&#xff0c;如何用本地的代码调试远程服务器上的程序呢 在web服务器上添加jvm参数,如以下是我们启动jetty服务器的参数&#xff0c;8000代表的是远程debug的端口号 java -Xdebug -Xrun…

前端控件JQuery Datatables使用——常用功能初始化

本文用于自己记录&#xff0c;忘记时可以用来回顾。点击这里进入JQuerydatatable官网API地址 JQuery Datatables初始化 个人比较喜欢JQueryDatatables的Bootstrap4风格&#xff0c;所以文章以Bootstrap4风格为例。 JQueryDatatable的初始化很简单&#xff0c;按照官网的举例说…

ASP.NET中常用的26个优化性能方法(1-10)

1. 数据库访问性能优化 数据库的连接和关闭 访问数据库资源需要创建连接、打开连接和关闭连接几个操作。这些过程需要多次与数据库交换信息以通过身份验证&#xff0c;比较耗费服务器资源。ASP.NET中提供了连接池(Connection Pool)改善打开和关闭数据库对性能的影响。系统将用户…