先看看下面的網上的一個測試代碼:
復制代碼 代碼如下:
<?php
$a = 9.45*100;
var_dump($a);
var_dump(intval($a));
$a = 945*1.00;
var_dump($a);
var_dump(intval($a));
?><SPAN style="WIDOWS: 2; TEXT-TRANSFORM: none; TEXT-INDENT: 0px; DISPLAY: inline !important; FONT: 12px Simsun; WHITE-SPACE: normal; ORPHANS: 2; FLOAT: none; LETTER-SPACING: normal; COLOR: #000000; WORD-SPACING: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px"><SPAN><SPAN></SPAN></SPAN></SPAN><SPAN><SPAN></SPAN></SPAN>
運行結果:float(945) int(944) float(945) int(945)
這個代碼雖然把結果都告訴了,但是很多人還是看不懂,這樣就解釋不了為什麼會有意想不到的轉型情況發生。
網上對這個情況講的都模稜兩可不知所雲的。我在這裡簡單的解釋下:
9.45這個數字在我們看到的是這樣的,但是機器內部卻不是這個,而是9.44999999999999999...。所以:
9.449999*100 = 944.9999。這樣就可以看懂了吧?intval把尾數直接去掉了,這個叫神馬來的呵呵忘了名字了.這樣說來,intval和floor()函數差不多咯。呵呵。這個也是我之前沒有察覺到的。也沒注意到intval會向下捨入。
而 1.00就沒有什麼1.0099999這樣的了,所以945*1.00就會出現一個float的945.那intval去轉型自然就不會出現944的情況了。
還有些經典考試題,如:intval((0.1+0.7)*10) 等於7而不是8的。都是這個道理。好了。就這麼簡單的說說。至少比網上一大堆的不知所雲好的多。