Maison php教程 php手册 Php入门教程之PHP 数据类型用法详解

Php入门教程之PHP 数据类型用法详解

May 25, 2016 pm 04:48 PM
入门教程 数据类型 用法

数据类型在php并不像java中那详细那么多种类型,下面我来给各位同学介绍php 数据类型的一些基础知道,各位同学可参考.

PHP 数据类型

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

四种标量类型:

1.string(字符串)
2.integer(整型)
3.float(浮点型,也作 double )
4.boolean(布尔型)
Copier après la connexion

两种复合类型:

1.array(数组)
2.object(对象)
Copier après la connexion

两种特殊类型:

1.resource(资源)
2.NULL(空)
Copier après la connexion

查看变量类型

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

$bool = TRUE; // 布尔型

$str = "foo"; // 字符串

$int = 12; // 整型

echo gettype($bool); // 输出 boolean

echo gettype($str); // 输出 string

echo gettype($int); // 输出 integer


?>

判断变量类型

如果想通过判断变量类型来可以使用 is_type 函数:

$var_int = 12;

// 如果 $var_int 是 int 类型,这进行加法

if (is_int($var_int)) {

    $var_int = $var_int + 4;

}

echo $var_int; // 输出 16


?>

以上基本就是PHP数据类型的基本内容,大家如果想了解具体每个数据类型的用法,可以查阅PHP手册,里面有详细的说明.

数据类型转换

PHP数据类型有三种转换方式:

在要转换的变量之前加上用括号括起来的目标类型

使用3个具体类型的转换函数,intval()、floatval()、strval()

使用通用类型转换函数settype(mixed var,string type)

第一种转换方式: (int)  (bool)  (float)  (string)  (array) (object)

$num1 = 3.14;

$num2 = (int)$num1;

var_dump($num1); //输出float(3.14)

var_dump($num2); //输出int(3)


?>

第二种转换方式:  intval()  floatval()  strval()

$str = "123.9abc";

$int = intval($str); //转换后数值:123

$float = floatval($str); //转换后数值:123.9

$str = strval($float); //转换后字符串:"123.9"


?>

第三种转换方式: settype();

$num4 = 12.8;

$flg = settype($num4, "int");

var_dump($flg); //输出bool(true)

var_dump($num4); //输出int(12)


?>

PHP数据类型隐性转换的陷阱,我这里说的是php5+上跑的,php4的请飘过.先把错误报告打开,以防看不到错误信息

error_reporting(E_ALL);

ini_set('display_errors', true);

?>

根据php manual 中 http://www.php.net/manual/zh/language.operators.comparison.php 

"Comparison Operators" 一章的说明可知,number 和string进行比较的时候,会先将string类型首先转化为number,然后再进行比较操作.

1.类型自动转换为数组

当我们把一个非数组的变量当做数组来调用的时候,该变量在调用时数据类型临时自动转换成数组.

实例代码如下:

$str = 'string';

var_dump($str['aaa']); // string(1) "s"

var_dump($str); // string(6) "string"

if ($str['aaa'] === $str[0]) {

    print "===";

}

?>

如下例子可以明显的看出下标类型自动转换在发生.

$link = 'yulans';

$key = '1-10';

echo "$link[$key]\n"; // 同 $link[1]

echo "{$link[$key]}\n"; // 同 $link[1]

//echo "$link['$key']\n";  // 报错

echo "{$link['$key']}\n"; // 同 $link[0]


?>

这里字符串在 var_dump($str['aaa']) 被临时转换成了数组 array('s','t','r','i', 'n','g'),而用关联数组方式

$str['aaa']读取索引数组的值,关联数组的下标'aaa'将被转换成整形下标,因而在这里的$str['aaa']全等于$str[0].其他数据类型隐性转换成数组也隐藏有陷阱,一般都不是报出undefined index错误.

举例如下代码:

/** 

 * 测试变量隐性转换成数组

 *

 * @param mixed $param

 */

function test2Arr($param) {

    var_dump($param['abc']);

}

test2Arr(false); // NULL

test2Arr(123); // NULL

test2Arr(123.456); // NULL

test2Arr('string'); // string(1) "s"

test2Arr(array(

    'abc' => 'text'

)); // string(4) text

test2Arr(new ArrayObject()); // Notice: undefined index: abc


?>

解决办法:

函数参数数据类型是数组的时候,防止用户输入字符串导致错误,如下例子,当添加用户的时候,我们要求用户必须输入用户名.没有哪个SB把要求是数组的参数传入字符串,但是防人之心不可无,说不定我连续工作超过十几个小时后一不小心就成那个SB了,又或许某人想绕过代码执行操作.

/** 

 * 添加用户(错误的写法)

 *

 * @param array $user

 */

function addUser($user) {

    if (emptyempty($user['name'])) { // 这里当输入类型是不为空的字符串的时候会出错,

        echo "用户名必填\n";

        return false;

    }

    // do sth.

    echo "测试\n";

    return true;

}

/** 

 * 添加用户(正确的写法)

 *

 * @param array $user

 */

function addUser2($user) {

    if (!is_array($user) || emptyempty($user['name'])) {

        echo "用户名必填\n";

        return false;

    }

    // do sth.

    echo "测试\n";

    return true;

}

$user = 'xiaoxiao';

addUser($user);

addUser2($user);

?>

2.纯数字字符串比较时自动转换成整形超过范围时发生溢出

$x1 = '111111111111111111';

$x2 = '111111111111111112';

echo ($x1 === $x2) ? "true" : "false"; // false 如我们所愿,这两个字符串确实不一样.

echo ($x1 == $x2) ? "true" : "false"; // true 这里被偷偷的转换类型了,

// 成了 echo (intval($x1) == intval($x2)) ? "true" : "false"; 整形溢出


?>

3、整形和字符串比较时数据类型隐性转换有可能发生问题

$number = 0;

$string = 'text';

if ($number == $string) {

    print "true";

} else {

    print "false";

}

?>

很遗憾这里输出的是 true,我们知道 $number === $string 肯定是false,手册上说 === 是比较值&&数据类型,而用 == 只是比较值,$number == $string 这里不是比较值吗? '0' 和 'text' 明显不一样啊.小心了,这里的$string是先被秘密转成和$number一样的整形再比较的,$number == (int)$string的确是true

4. in_array 小陷阱

因为in_array会将0 和's' 进行比较,0是number类型,'s'是string类型, 's'转化为number的结果为0,而0 == 0 的结果是true,所以in_array(0, array('s', 'ss'))的结果也是true.如果把in_array 的第三个参数strict设置为 true,比较的时候 就会判断值和类型是否都相当.如果都相当的话,才会返回true,否则返回false.


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel type de données doit être utilisé pour le champ sexe dans la base de données MySQL ? Quel type de données doit être utilisé pour le champ sexe dans la base de données MySQL ? Mar 14, 2024 pm 01:21 PM

Dans une base de données MySQL, les champs de genre peuvent généralement être stockés en utilisant le type ENUM. ENUM est un type d'énumération qui nous permet d'en sélectionner une comme valeur d'un champ parmi un ensemble de valeurs prédéfinies. ENUM est un bon choix pour représenter une option fixe et limitée comme le sexe. Examinons un exemple de code spécifique : supposons que nous ayons une table appelée « utilisateurs » qui contient des informations sur l'utilisateur, y compris son sexe. Maintenant, nous voulons créer un champ pour le genre, nous pouvons concevoir la structure du tableau comme ceci : CRE

Quel est le meilleur type de données pour les champs de genre dans MySQL ? Quel est le meilleur type de données pour les champs de genre dans MySQL ? Mar 15, 2024 am 10:24 AM

Dans MySQL, le type de données le plus approprié pour les champs de genre est le type d'énumération ENUM. Le type d'énumération ENUM est un type de données qui permet de définir un ensemble de valeurs possibles. Le champ genre est adapté à l'utilisation du type ENUM car le genre n'a généralement que deux valeurs, à savoir masculin et féminin. Ensuite, j'utiliserai des exemples de code spécifiques pour montrer comment créer un champ de genre dans MySQL et utiliser le type d'énumération ENUM pour stocker les informations de genre. Voici les étapes : Tout d'abord, créez une table nommée utilisateurs dans MySQL, y compris

Utilisation de la fonction WPSdatedif Utilisation de la fonction WPSdatedif Feb 20, 2024 pm 10:27 PM

WPS est une suite logicielle bureautique couramment utilisée et la fonction de table WPS est largement utilisée pour le traitement des données et les calculs. Dans le tableau WPS, il existe une fonction très utile, la fonction DATEDIF, qui permet de calculer le décalage horaire entre deux dates. La fonction DATEDIF est l'abréviation du mot anglais DateDifference. Sa syntaxe est la suivante : DATEDIF(start_date,end_date,unit) où start_date représente la date de début.

Guide du débutant : Partez de zéro et apprenez MyBatis étape par étape Guide du débutant : Partez de zéro et apprenez MyBatis étape par étape Feb 19, 2024 am 11:05 AM

Tutoriel d'introduction MyBatis concis et facile à comprendre : écrivez votre premier programme étape par étape MyBatis est un framework de couche de persistance Java populaire qui simplifie le processus d'interaction avec les bases de données. Ce didacticiel vous montrera comment utiliser MyBatis pour créer et effectuer des opérations de base de données simples. Étape 1 : configuration de l'environnement Tout d'abord, assurez-vous que votre environnement de développement Java a été installé. Ensuite, téléchargez la dernière version de MyBatis et ajoutez-la à votre projet Java. Vous pouvez le télécharger depuis le site officiel de MyBatis

Carte mentale de la syntaxe Python : compréhension approfondie de la structure du code Carte mentale de la syntaxe Python : compréhension approfondie de la structure du code Feb 21, 2024 am 09:00 AM

Python est largement utilisé dans un large éventail de domaines grâce à sa syntaxe simple et facile à lire. Il est crucial de maîtriser la structure de base de la syntaxe Python, à la fois pour améliorer l’efficacité de la programmation et pour acquérir une compréhension approfondie du fonctionnement du code. À cette fin, cet article fournit une carte mentale complète détaillant divers aspects de la syntaxe Python. Variables et types de données Les variables sont des conteneurs utilisés pour stocker des données en Python. La carte mentale affiche les types de données Python courants, notamment les entiers, les nombres à virgule flottante, les chaînes, les valeurs booléennes et les listes. Chaque type de données a ses propres caractéristiques et méthodes de fonctionnement. Opérateurs Les opérateurs sont utilisés pour effectuer diverses opérations sur les types de données. La carte mentale couvre les différents types d'opérateurs en Python, tels que les opérateurs arithmétiques, ratio

Explication détaillée et introduction à l'utilisation de la fonction MySQL ISNULL Explication détaillée et introduction à l'utilisation de la fonction MySQL ISNULL Mar 01, 2024 pm 05:24 PM

La fonction ISNULL() dans MySQL est une fonction utilisée pour déterminer si une expression ou une colonne spécifiée est NULL. Il renvoie une valeur booléenne, 1 si l'expression est NULL, 0 sinon. La fonction ISNULL() peut être utilisée dans l'instruction SELECT ou pour un jugement conditionnel dans la clause WHERE. 1. La syntaxe de base de la fonction ISNULL() : ISNULL(expression) où expression est l'expression permettant de déterminer si elle est NULL ou

Comment utiliser les raccourcis Apple Comment utiliser les raccourcis Apple Feb 18, 2024 pm 05:22 PM

Comment utiliser les commandes de raccourci Apple Avec le développement continu de la technologie, les téléphones mobiles sont devenus un élément indispensable de la vie des gens. Parmi les nombreuses marques de téléphones mobiles, les téléphones mobiles Apple ont toujours été appréciés des utilisateurs pour leurs systèmes stables et leurs fonctions puissantes. Parmi eux, la fonction de commande de raccourci Apple rend l’expérience du téléphone mobile des utilisateurs plus pratique et efficace. Apple Shortcuts est une fonctionnalité lancée par Apple pour iOS12 et les versions ultérieures. Elle aide les utilisateurs à simplifier les opérations de leur téléphone mobile en créant et en exécutant des commandes personnalisées pour obtenir un travail plus efficace et.

Utilisez CSS Transform pour transformer des éléments Utilisez CSS Transform pour transformer des éléments Feb 24, 2024 am 10:09 AM

Utilisation de Transform en CSS La propriété Transform de CSS est un outil très puissant qui peut effectuer des opérations telles que la traduction, la rotation, la mise à l'échelle et l'inclinaison des éléments HTML. Cela peut changer radicalement l’apparence des éléments et rendre les pages Web plus créatives et dynamiques. Dans cet article, nous présenterons en détail les différentes utilisations de Transform et fournirons des exemples de code spécifiques. 1. Traduire (Traduire) Traduire fait référence au déplacement d'un élément sur une distance spécifiée le long de l'axe x et de l'axe y. Sa syntaxe est la suivante : tran

See all articles