问题来源:用Java代码写了一个计算公式,包含除法和对数和取反,在页面上出现了-infinity,不知道这是什么问题,网上找答案才明白意思是负的无穷大。java
思考:为何会出现这种状况呢?这是哪里的问题啊;sql
解决:根据一些博客上的分析,出现的缘由是除法的除数为0,打印出用到的变量值,看到时间间隔变量是0,溯源到sql查询的结果,sql是用的时间函数再运算的结果,提取出来运行,源数据相同 ,做减法确定是0了,再看一下数据库中的数据列,全是同样的状况,可是实际上不该该是相同的时间,因此,开始时间和结束时间在插入的时候就有问题了,因此判断不是个人问题,啊哈哈哈啊哈哈。数据库
知识扩展:函数
在java语言中,提供了三个特殊的浮点数值:正无穷大、负无穷大和非数(NaN),功能是表示溢出和出错。code
无穷大:一个正数除以0.0或一个负数除以0.0将获得一个正无穷大或负无穷数(Infinity)。博客
非数:0.0除以0.0或着负数开方将获得一个非数(NaN(“不是一个数字(Not a Number)”的缩写))。数学
用法:it
任何浮点操做,只要它的一个或多个操做数为NaN,那么其结果为NaN。class
NaN是非数字,参与算术运算都为NaN,与其余数字比较结果都为false(包括本身)。变量
正无穷和负无穷仍然保持数学上的定义。
double i = 1.0 / 0; System.out.println(i); //Infinity System.out.println(i + 1); //Infinity System.out.println(i == i + 1); //true i = 0.0 / 0; System.out.println(i); //NaN System.out.println(i + 1); //NaN System.out.println(i == i + 1); //false