萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> php入門教程之數值型數據類型詳解

php入門教程之數值型數據類型詳解

PHP是弱類型的所在在使用時不需要定義變量的類型可以邊使用邊給數字定義類型,你給變量什麼類型變量就自動是什麼類型。

在PHP裡,變量的類型是賦給它們的值決定的。如果賦的值是整型,那麼變量就是整型,如果是字符串,就是字符串型。

 代碼如下 復制代碼

<?php
 $name="your name";//name位string類型。
 $total=12;        //total為整型
?>


PHP 支持八種原始類型(type)。

四種標量類型:

string(字符串)
integer(整型)
float(浮點型,也作 double )
boolean(布爾型)
兩種復合類型:

array(數組)
object(對象)
兩種特殊類型:

resource(資源)
NULL(空)
查看變量類型
通過 gettype() 函數可以方便的查看某個變量的類型:

 代碼如下 復制代碼

<?php
$var_bool = TRUE;     // a boolean
$var_str  = "foo";     // a string
$var_int  = 12;      // an integer

echo gettype($var_bool);    // 輸出 boolean
echo gettype($var_str);     // 輸出 string
echo gettype($var_int);     // 輸出 integer
?>

提示
由於歷史原因,如果是 float 類型數據,gettype() 函數返回的是 double,而不是 float 。
如果想查看某個表達式的值和類型,請使用用 var_dump() 函數。
判斷變量類型
如果想通過判斷變量類型來確定下一步邏輯動作,不要使用 gettype() ,而使用 is_type 系列函數:

 代碼如下 復制代碼

<?php
$var_int  = 12;

// 如果 $var_int 是 int 類型,這進行加法
if (is_int($var_int)) {
    $var_int = $var_int+4;
}
echo $var_int;  // 輸出 16
?>


 

integer數據類型

一個 integer 是集合 Z={…,-2,-1,0,1,2,…}  中的一個數。整型值可以用十進制,十六進制或八進制符號指定,前面可以加上可選的符號(-或者+)。

如果用八進制符號,數字前必須加上 0(零),用十六進制符號數字前必須加上 0x。

例如:

 代碼如下 復制代碼

<?php

$a=1234;          //十進制數

$a=-123;          //一個負數

$a=0123;          //八進制數(等於十進制的 83)

$a=0x1A;          //十六進制數(等於十進制的 26)

?>

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

八進制表示數字前必須加上 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),則結果不確定,因為沒有足夠的精度使浮點數給出一個確切的整數結果。在此情況下沒有警告,甚至沒有任何通知!

布爾型是最簡單的類型。boolean 表達了真值,可以為 TRUE 或 FALSE。要指定一個 布爾值,使用關鍵字 TRUE 或 FALSE,兩個都是大小寫不敏感的。

 代碼如下 復制代碼

<?php

$foo=True;          //將 true 值賦給$foo

?>

以下值被認為是 FALSE:

�    布爾值 FALSE

�    整型值 0(零)

�    浮點型值 0.0(零)

�    空白字符串和字符串 "0"

�    沒有成員變量的數組

�    沒有單元的對象

�    特殊類型 NULL(包括尚未設定的變量) 所有其它值都被認為是 TRUE(包括任何資源)

float數據類型

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

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

 代碼如下 復制代碼

<?php

$a = 76.60;
$b = 76.00;

$c = $a-$b;
var_dump($c);

?>

輸出是
float(0.59999999999999)


然而76.70就不會出現這個問題... 後來發現

 

 代碼如下 復制代碼

$a = 76.60; 
$d = intval($a*100); 
var_dump($d); 
$a = 76.60;
$d = intval($a*100);
var_dump($d);
輸出是int(7659)

那確實是76.60的問題...  (Java,Obj-C下面也重現了這個問題)

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

浮點型

浮點數(也叫“floats”,“doubles”或“real numbers”)可以用以下任何語法定義:

 代碼如下 復制代碼

<?php

$a=1.234;

$a=1.2e3;

$a=7E-10;

?>

在php中這幾種數字類型我們都詳細的講解了有需要了解的朋友可以參考一下。

copyright © 萬盛學電腦網 all rights reserved