PHP是弱类型的所在在使用时不需要定义变量的类型可以边使用边给数字定义类型,你给变量什么类型变量就自动是什么类型.
在PHP里,变量的类型是赋给它们的值决定的.如果赋的值是整型,那么变量就是整型,如果是字符串,就是字符串型.
实例代码如下:
- <?php
- $name="your name";
- $total=12;
- ?>
PHP 支持八种原始类型(type).
四种标量类型:
string(字符串)
integer(整型)
float(浮点型,也作 double )
boolean(布尔型)
两种复合类型:
array(数组)
object(对象)
两种特殊类型:
resource(资源)
NULL(空)
查看变量类型
通过 gettype() 函数可以方便的查看某个变量的类型:
实例代码如下:
- <?php
- $var_bool = TRUE;
- $var_str = "foo";
- $var_int = 12;
- echo gettype($var_bool);
- echo gettype($var_str);
- echo gettype($var_int);
- ?>
提示
由于历史原因,如果是 float 类型数据,gettype() 函数返回的是 double,而不是 float .
如果想查看某个表达式的值和类型,请使用用 var_dump() 函数.
判断变量类型
如果想通过判断变量类型来确定下一步逻辑动作,不要使用 gettype() ,而使用 is_type 系列函数:
实例代码如下:
- <?php
- $var_int = 12;
-
- if (is_int($var_int)) {
- $var_int = $var_int+4;
- }
- echo $var_int;
- ?>
integer数据类型:
一个 integer 是集合 Z={…,-2,-1,0,1,2,…} 中的一个数.整型值可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(-或者+).
如果用八进制符号,数字前必须加上 0(零),用十六进制符号数字前必须加上 0x.
实例代码如下:
- <?php
- $a=1234;
- $a=-123;
- $a=0123;
- $a=0x1A;
- ?>
整型值可以使用十进制,十六进制或八进制进行表示,前面可以加上可选的符号(- 或者 +).
八进制表示数字前必须加上 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;
- ?>
以下值被认为是 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中这几种数字类型我们都详细的讲解了有需要了解的朋友可以参考一下. |