澳门皇冠金沙网站-澳门皇冠844网站

热门关键词: 澳门皇冠金沙网站,澳门皇冠844网站

php入门教程之数值型数据类型详解,php中浮点型

PHP 支持8种基本的数据类型。

在PHP里,变量的类型是赋给它们的值决定的。如果赋的值是整型,那么变量就是整型,如果是字符串,就是字符串型。

取值只能为True或者False,当其他类型转化为boolean类型时,以下值被认为是 FALSE:

四种标量类型:

 代码如下

the 布尔值 FALSE 自身
the 整型值 0 (零)
the 浮点型值 0.0 (零)
空字符串, 以及字符串 "0"
不包括任何元素的数组
不包括任何成员变量的对象(仅PHP 4.0 适用)
特殊类型 NULL (包括尚未设定的变量)
从没有任何标记(tags)的XML文档生成的SimpleXML 对象
所有其它值都被认为是 TRUE(包括任何资源)。

  • boolean (布尔型)
  • integer (整型)
  • float (浮点型, 也称作 double)
  • string (字符串)

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

integer数据类型:

两种复合类型:

PHP 支持八种原始类型(type)。

整型值可以使用十进制,十六进制或八进制进行表示,前面可以加上可选的符号(- 或者 )。

  • array (数组)
  • object (对象)

四种标量类型:

八进制表示数字前必须加上 0(零),十六进制表示数字前必须加上 0x。

最后是两种特殊类型:

string(字符串)
integer(整型)
float(浮点型,也作 double )
boolean(布尔型)
两种复合类型:

整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。PHP 不支持无符号整数。Integer值的字长可以用常量PHP_INT_SIZE来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值可以用常量PHP_INT_MAX来表示。

  • resource (资源)
  • NULL (NULL)

array(数组)
object(对象)
两种特殊类型:

如果给定的一个数超出了 integer 的范围,将会被解释为 float。同样如果执行的运算结果超出了 integer 范围,也会返回 float。

boolean数据类型:

resource(资源)
NULL(空)
查看变量类型
通过 gettype() 函数可以方便的查看某个变量的类型:

PHP 中没有整除的运算符。1/2 产生出 float 0.5。可以总是舍弃小数部分,或者使用 round() 函数。

取值只能为True或者False,当其他类型转化为boolean类型时,以下值被认为是 FALSE

 代码如下

要明确地将一个值转换为 integer,用 (int) 或 (integer) 强制转换。不过大多数情况下都不需要强制转换,因为当运算符,函数或流程控制需要一个 integer 参数时,值会自动转换。还可以通过函数 intval() 来将一个值转换成整型。

  • the 布尔值 FALSE 自身
  • the 整型值 0 (零)

  • the 浮点型值 0.0 (零)

  • 空字符串, 以及字符串 "0"
  • 不包括任何元素的数组

  • 不包括任何成员变量的对象(仅PHP 4.0 适用)

  • 特殊类型 NULL (包括尚未设定的变量)
  • 从没有任何标记(tags)的XML文档生成的SimpleXML 对象

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

从布尔值转换,FALSE 将产生出 0(零),TRUE 将产生出 1(壹)。
从浮点数转换,当从浮点数转换成整数时,将向零取整。如果浮点数超出了整数范围(通常为 /- 2.15e 9 = 2^31),则结果不确定,因为没有足够的精度使浮点数给出一个确切的整数结果。在此情况下没有警告,甚至没有任何通知!

所有其它值都被认为是 TRUE(包括任何资源)。

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

integer数据类型:

提示
由于历史原因,如果是 float 类型数据,gettype() 函数返回的是 double,而不是 float 。
如果想查看某个表达式的值和类型,请使用用 var_dump() 函数。
判断变量类型
如果想通过判断变量类型来确定下一步逻辑动作,不要使用 gettype() ,而使用 is_type 系列函数:

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

整型值可以使用十进制,十六进制或八进制进行表示,前面可以加上可选的符号(- 或者 )。

 代码如下

定义整型的例子:

八进制表示数字前必须加上 0(零),十六进制表示数字前必须加上 0x

<?php
$var_int  = 12;

$var_int = 12345;
整型值可以用十进制,十六进制或八进制符号指定,如果用八进制符号,数字前必须加上 0(零),用十六进制符号数字前必须加上 0x:

整型数的字长和平台有关,尽管通常最大值是大约二十亿(32 位有符号)。PHP 不支持无符号整数。Integer值的字长可以用常量PHP_INT_SIZE来表示,自 PHP 4.4.0 和 PHP 5.0.5后,最大值可以用常量PHP_INT_MAX来表示。

// 如果 $var_int 是 int 类型,这进行加法
if (is_int($var_int)) {
    $var_int = $var_int 4;
}
echo $var_int;  // 输出 16
?>

$var_int = 0123;  // 八进制数(等于十进制的 83)
$var_int2 = 0x1A;  // 十六进制数(等于十进制的 26)
提示:整型数据不需要单引号或双引号,否则会被当作字符串类型来定义。

如果给定的一个数超出了 integer 的范围,将会被解释为 float。同样如果执行的运算结果超出了 integer 范围,也会返回 float。

 

整数溢出
如果给定的一个数超出了 integer 的范围,将会被解释为 float类型 。同样如果执行的运算结果超出了 integer 范围,也会返回 float。

PHP 中没有整除的运算符。1/2 产生出 float 0.5。可以总是舍弃小数部分,或者使用 round() 函数。

integer数据类型

整型数的范围和平台有关,通常最大值是大约二十亿(32 位有符号)。

要明确地将一个值转换为 integer,用 (int)(integer) 强制转换。不过大多数情况下都不需要强制转换,因为当运算符,函数或流程控制需要一个 integer 参数时,值会自动转换。还可以通过函数 intval() 来将一个值转换成整型。

一个 integer 是集合 Z={…,-2,-1,0,1,2,…}  中的一个数。整型值可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(-或者 )。

 

从布尔值转换,FALSE 将产生出 0(零),TRUE 将产生出 1(壹)。

如果用八进制符号,数字前必须加上 0(零),用十六进制符号数字前必须加上 0x。

float数据类型

从浮点数转换,当从浮点数转换成整数时,将向零取整。如果浮点数超出了整数范围(通常为 /- 2.15e 9 = 2^31),则结果不确定,因为没有足够的精度使浮点数给出一个确切的整数结果。在此情况下没有警告,甚至没有任何通知!

float数据类型

浮点数的字长和平台相关,尽管通常最大值是 1.8e308 并具有 14 位十进制数字的精度(64 位 IEEE 格式)。

显然简单的十进制分数如同 0.10.7 不能在不丢失一点点精度的情况下转换为内部二进制的格式。这就会造成混乱的结果:例如,floor((0.1 0.7)10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似7.9*。

这和一个事实有关,那就是不可能精确的用有限位数表达某些十进制分数。例如,十进制的 1/3 变成了 0.3

所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。

例如:

浮点数的字长和平台相关,尽管通常最大值是 1.8e308 并具有 14 位十进制数字的精度(64 位 IEEE 格式)。

您可能感兴趣的文章:

  • php封装好的人民币数值转中文大写类
  • PHP统计数值数组中出现频率最多的10个数字的方法
  • PHP查找数值数组中不重复最大和最小的10个数的方法
  • php中的Base62类(适用于数值转字符串)
  • 探讨PHP函数ip2long转换IP时数值太大产生负数的解决方法
  • php数字游戏 计算24算法
  • PHP计算加权平均数的方法
  • PHP之浮点数计算比较以及取整数不准确的解决办法
  • 总结PHP中数值计算的注意事项

 代码如下

显然简单的十进制分数如同 0.1 或 0.7 不能在不丢失一点点精度的情况下转换为内部二进制的格式。这就会造成混乱的结果:例如,floor((0.1 0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9。

<?php

这和一个事实有关,那就是不可能精确的用有限位数表达某些十进制分数。例如,十进制的 1/3 变成了 0.3。

$a=1234;          //十进制数

float, 他有1个符号位,8个指数位及24个有效数位(只保存23位). 当然刚才的binary32中的binary表明他是以二进制形式保存的.下图是一个float在内存中的表示. 

$a=-123;          //一个负数

第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 .

本文由澳门皇冠金沙网站发布于编辑程序,转载请注明出处:php入门教程之数值型数据类型详解,php中浮点型