php中浮點型(float)和整型(integer)資料類型詳解_PHP教程

來源:互聯網
上載者:User
文章分析了關於php中浮點型(float)和整型(integer)資料類型的用法區別以及在那種情況下會出現資料長度不夠。

取值只能為True或者False,當其他類型轉化為boolean類型時,以下值被認為是 FALSE:

the 布爾值 FALSE 自身
the 整型值 0 (零)
the 浮點型值 0.0 (零)
Null 字元串, 以及字串 "0"
不包括任何元素的數組
不包括任何成員變數的對象(僅PHP 4.0 適用)
特殊類型 NULL (包括尚未設定的變數)
從沒有任何標記(tags)的XML文檔產生的SimpleXML 對象
所有其它值都被認為是 TRUE(包括任何資源)。


integer資料類型:


整型值可以使用十進位,十六進位或八進位進行表示,前面可以加上可選的符號(- 或者 +)。

八進位表示數字前必須加上 0(零),十六進位表示數字前必須加上 0x。

整型數的字長和平台有關,儘管通常最大值是大約二十億(32 位有符號)。PHP 不支援不帶正負號的整數。Integer值的字長可以用常量PHP_INT_SIZE來表示,自 PHP 4.4.0 和 PHP 5.0.5後,最大值可以用常量PHP_INT_MAX來表示。

如果給定的一個數超出了 integer 的範圍,將會被解釋為 float。同樣如果執行的運算結果超出了 integer 範圍,也會返回 float。

PHP 中沒有整除的運算子。1/2 產生出 float 0.5。可以總是捨棄小數部分,或者使用 round() 函數。

要明確地將一個值轉換為 integer,用 (int) 或 (integer) 強制轉換。不過大多數情況下都不需要強制轉換,因為當運算子,函數或流程式控制制需要一個 integer 參數時,值會自動轉換。還可以通過函數 intval() 來將一個值轉換成整型。

從布爾值轉換,FALSE 將產生出 0(零),TRUE 將產生出 1(壹)。
從浮點數轉換,當從浮點數轉換成整數時,將向零取整。如果浮點數超出了整數範圍(通常為 +/- 2.15e+9 = 2^31),則結果不確定,因為沒有足夠的精度使浮點數給出一個確切的整數結果。在此情況下沒有警告,甚至沒有任何通知!

整型是指 {..., -2, -1, 0, 1, 2, ...} 集合中的一個數。

定義整型的例子:

$var_int = 12345;
整型值可以用十進位,十六進位或八進位符號指定,如果用八進位符號,數字前必須加上 0(零),用十六進位符號數字前必須加上 0x:

$var_int = 0123; // 八位元(等於十進位的 83)
$var_int2 = 0x1A; // 十六進位數(等於十進位的 26)
提示:整型資料不需要單引號或雙引號,否則會被當作字串類型來定義。

整數溢出
如果給定的一個數超出了 integer 的範圍,將會被解釋為 float類型 。同樣如果執行的運算結果超出了 integer 範圍,也會返回 float。

整型數的範圍和平台有關,通常最大值是大約二十億(32 位有符號)。

float資料類型


浮點數的字長和平台相關,儘管通常最大值是 1.8e308 並具有 14 位十進位數位精度(64 位元 IEEE 格式)。

顯然簡單的十進位分數如同 0.1 或 0.7 不能在不丟失一點點精度的情況下轉換為內部二進位的格式。這就會造成混亂的結果:例如,floor((0.1+0.7)*10) 通常會返回 7 而不是預期中的 8,因為該結果內部的表示其實是類似 7.9。

這和一個事實有關,那就是不可能精確的用有限位元表達某些十進位分數。例如,十進位的 1/3 變成了 0.3。

float, 他有1個符號位,8個指數位及24個有效數位(只儲存23位). 當然剛才的binary32中的binary表明他是以二進位形式儲存的.是一個float在記憶體中的表示.


第31位是符號(sign)位,23~30是指數(exponent)位,0~22是有效數(fraction小數)位. 其中有效數中還有一個隱藏位,永遠是1. 所以有效數位的那部分永遠是1.xxxxxxx...(23個x).另外一個要注意的地方是指數的表示,在IEEE754中規定是用位移指數的方式表示的,意思是指數位中的數減去127後的數來表示最終的指數.比較上面的圖中指數部分是01111100,轉換成十進位數為124,然後減去127,結果是-3,也就是說指數部分是2-3=1/8=0.125 .那麼有效數部分呢? 加上隱藏的位之後表示為 1.01000000000000000000000=1+(1*2-2)=5/4=1.25 ,所以上面表示的數就是 1/8 * 5/4 = 0.15625 .


指數可表示的最大值和最小值分類是127和-126,按理說8位應該可表示-128~127之間,設定成-126的目的是為了防止最小的數(1/2-126)不上溢出(這個有點難理解,文檔上是這麼說的).這裡的127,-126是作為2的指數表示的,那麼當表示成10的指數時應該是多少呢? 我們知道函數 y=10x 的反函數為 x = log10y ,當然這裡的10可以後任何其它數. 所以2127=10x => x = log2(127) = 38.23 約等於38, log2(-126) = -37.99約等於-37,由是就有了-37~38這樣的指數範圍. 那麼7位有效數字呢? 同樣的道理 log2(24) = 7.22 ,也就是說24位二進位有效位相當於107 的數量級,也就是7位有效數字. 那麼浮點數最大可以表示的數是多少呢? 我們知道指數最大是127,有效數最大的話是每位全部都是1,所以這個數應該是

1.11111111111111111111111*2127 ≈ 3.4028234 * 1038 .


float類型


$a = 1.234;
$b = 1.2e3;
$c = 7E-10;
?>

使用PHP的float類型需要注意的是:PHP的float類型的精度有點問題。如果需要高精度的數學計算,可以使用php提供的專用的數學函數 arbitrary precision math functions系列和gmp系列函數。還有就是不要試圖進行比較float類型的變數。

注:浮點數的字長和平台相關,儘管通常最大值是 1.8e308 並具有 14 位十進位數位精度(64 位元 IEEE 格式)


總結:
float的長度和平台有相,通常最大值是 1.8e308 並具有 14 位十進位數位精度,如果給定的一個數超出了 integer 的範圍,將會被解釋為 float類型 ,整型數的範圍和平台有關,通常最大值是大約二十億(32 位有符號)頁整有個好處就是同樣如果執行的運算結果超出了 integer 範圍,也會返回 float。

http://www.bkjia.com/PHPjc/629172.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/629172.htmlTechArticle文章分析了關於php中浮點型(float)和整型(integer)資料類型的用法區別以及在那種情況下會出現資料長度不夠。 取值只能為True或者False,當其他...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.