php 代码
intval((0.7+0.1)*10)js 代码
parseInt((0.7+0.1)*10)
刚才测试了似乎跟语言没关系,所有语言都这样。
这和计算机的小数表示有关,通常情况下,小数是用 表示的:
计算机中的浮点数 浮点指的是带有小数的数值,浮点运算即是小数的四则运算,常用来测量电脑运算速度。大部份计算机采用二進制(b=2)的表示方法。 (bit)是衡量浮点数所需存储空间的单位,通常为32位或64位,分别被叫作 和 。比如单精度的浮点数,由32个bit位。按照 标准,32位中有 1位是符号位(sign) 8位是指数位(exponent) 23位是数值 (fraction) 如下图所示: 那么这个数的数值就是 这样比如对于0.5,就可以表示成sign = 0, exponent = -1, fraction = 1 但实际上 对表示方法还做了一些优化,比如fraction必须是1-2之间的一个小数,这样fraction就只用表示小数位,而exponent的实际值是exponent + offset. 这样实际的计算公式是:
比如0.5的float表示为: 0 01111110 000 00000000 00000000 0000 其中0为符号位 01111110为指数位,十进制为126, 所以实际的exponent为126 - 127 = -1, 而 000 00000000 00000000 0000 为fraction,十进制为0, 所以0.5f =这种表示方法带来的问题就是很多浮点数不能精确表示,比如0.1的浮点数表示为: 0 0111101 110011001100110011001101 实际上值为