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

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

May 25, 2016 pm 04:48 PM
Tutorial Bermula jenis data penggunaan

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

PHP 数据类型

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

四种标量类型:

1.string(字符串)
2.integer(整型)
3.float(浮点型,也作 double )
4.boolean(布尔型)
Salin selepas log masuk

两种复合类型:

1.array(数组)
2.object(对象)
Salin selepas log masuk

两种特殊类型:

1.resource(资源)
2.NULL(空)
Salin selepas log masuk

查看变量类型

通过 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.


Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah jenis data terbaik untuk medan jantina dalam MySQL? Apakah jenis data terbaik untuk medan jantina dalam MySQL? Mar 15, 2024 am 10:24 AM

Dalam MySQL, jenis data yang paling sesuai untuk medan jantina ialah jenis penghitungan ENUM. Jenis penghitungan ENUM ialah jenis data yang membenarkan definisi set nilai yang mungkin Medan jantina sesuai untuk menggunakan jenis ENUM kerana jantina biasanya hanya mempunyai dua nilai, iaitu lelaki dan perempuan. Seterusnya, saya akan menggunakan contoh kod khusus untuk menunjukkan cara mencipta medan jantina dalam MySQL dan menggunakan jenis penghitungan ENUM untuk menyimpan maklumat jantina. Berikut adalah langkah-langkahnya: Pertama, buat jadual bernama pengguna dalam MySQL, termasuk

Apakah jenis data yang harus digunakan untuk medan jantina dalam pangkalan data MySQL? Apakah jenis data yang harus digunakan untuk medan jantina dalam pangkalan data MySQL? Mar 14, 2024 pm 01:21 PM

Dalam pangkalan data MySQL, medan jantina biasanya boleh disimpan menggunakan jenis ENUM. ENUM ialah jenis penghitungan yang membolehkan kita memilih satu sebagai nilai medan daripada set nilai yang dipratentukan. ENUM ialah pilihan yang baik apabila mewakili pilihan tetap dan terhad seperti jantina. Mari lihat contoh kod tertentu: Katakan kita mempunyai jadual yang dipanggil "pengguna" yang mengandungi maklumat pengguna, termasuk jantina. Sekarang kita ingin mencipta medan untuk jantina, kita boleh mereka bentuk struktur jadual seperti ini: CRE

Panduan Pemula: Mulakan dari awal dan pelajari MyBatis langkah demi langkah Panduan Pemula: Mulakan dari awal dan pelajari MyBatis langkah demi langkah Feb 19, 2024 am 11:05 AM

Tutorial pengenalan MyBatis yang ringkas dan mudah difahami: tulis program pertama anda langkah demi langkah MyBatis ialah rangka kerja lapisan ketekunan Java yang popular yang memudahkan proses berinteraksi dengan pangkalan data. Tutorial ini akan menunjukkan kepada anda cara menggunakan MyBatis untuk mencipta dan melaksanakan operasi pangkalan data yang mudah. Langkah 1: Persediaan persekitaran Mula-mula, pastikan persekitaran pembangunan Java anda telah dipasang. Kemudian, muat turun versi terkini MyBatis dan tambahkannya pada projek Java anda. Anda boleh memuat turunnya dari laman web rasmi MyBatis

Penggunaan fungsi WPSdatedif Penggunaan fungsi WPSdatedif Feb 20, 2024 pm 10:27 PM

WPS ialah suite perisian pejabat yang biasa digunakan, dan fungsi jadual WPS digunakan secara meluas untuk pemprosesan dan pengiraan data. Dalam jadual WPS, terdapat fungsi yang sangat berguna, fungsi DATEDIF, yang digunakan untuk mengira perbezaan masa antara dua tarikh. Fungsi DATEDIF ialah singkatan daripada perkataan Inggeris DateDifference Sintaksnya adalah seperti berikut: DATEDIF(start_date,end_date,unit) dengan start_date mewakili tarikh mula.

Peta minda sintaks Python: pemahaman mendalam tentang struktur kod Peta minda sintaks Python: pemahaman mendalam tentang struktur kod Feb 21, 2024 am 09:00 AM

Python digunakan secara meluas dalam pelbagai bidang dengan sintaksnya yang ringkas dan mudah dibaca. Menguasai struktur asas sintaks Python adalah penting, kedua-duanya untuk meningkatkan kecekapan pengaturcaraan dan untuk mendapatkan pemahaman yang mendalam tentang cara kod tersebut berfungsi. Untuk tujuan ini, artikel ini menyediakan peta minda komprehensif yang memperincikan pelbagai aspek sintaks Python. Pembolehubah dan Jenis Data Pembolehubah ialah bekas yang digunakan untuk menyimpan data dalam Python. Peta minda menunjukkan jenis data Python biasa, termasuk integer, nombor titik terapung, rentetan, nilai Boolean dan senarai. Setiap jenis data mempunyai ciri dan kaedah operasinya sendiri. Operator Operator digunakan untuk melaksanakan pelbagai operasi pada jenis data. Peta minda merangkumi jenis operator yang berbeza dalam Python, seperti operator aritmetik, nisbah

Cara menggunakan pintasan Apple Cara menggunakan pintasan Apple Feb 18, 2024 pm 05:22 PM

Cara menggunakan arahan pintasan Apple Dengan perkembangan teknologi yang berterusan, telefon bimbit telah menjadi bahagian yang amat diperlukan dalam kehidupan manusia. Di antara banyak jenama telefon bimbit, telefon bimbit Apple sentiasa digemari oleh pengguna kerana sistem yang stabil dan fungsi yang berkuasa. Antaranya, fungsi arahan pintasan Apple menjadikan pengalaman telefon mudah alih pengguna lebih mudah dan cekap. Pintasan Apple ialah ciri yang dilancarkan oleh Apple untuk iOS12 dan versi yang lebih baru Ia membantu pengguna memudahkan operasi telefon mudah alih mereka dengan mencipta dan melaksanakan perintah tersuai untuk mencapai kerja yang lebih cekap dan

Penerangan terperinci dan pengenalan penggunaan fungsi MySQL ISNULL Penerangan terperinci dan pengenalan penggunaan fungsi MySQL ISNULL Mar 01, 2024 pm 05:24 PM

Fungsi ISNULL() dalam MySQL ialah fungsi yang digunakan untuk menentukan sama ada ungkapan atau lajur yang ditentukan adalah NULL. Ia mengembalikan nilai Boolean, 1 jika ungkapan itu NULL, 0 sebaliknya. Fungsi ISNULL() boleh digunakan dalam pernyataan SELECT atau untuk pertimbangan bersyarat dalam klausa WHERE. 1. Sintaks asas fungsi ISNULL(): ISNULL(ungkapan) di mana ungkapan ialah ungkapan untuk menentukan sama ada ia NULL atau

Menggunakan kata kunci yang berbeza dalam menghuraikan SQL Menggunakan kata kunci yang berbeza dalam menghuraikan SQL Feb 18, 2024 pm 09:21 PM

Penjelasan terperinci tentang penggunaan berbeza dalam SQL Dalam pangkalan data SQL, kita sering menghadapi situasi di mana kita perlu mengalih keluar data pendua. Pada masa ini, kami boleh menggunakan kata kunci yang berbeza, yang boleh membantu kami mengalih keluar data pendua dan menjadikan hasil pertanyaan lebih jelas dan tepat. Penggunaan asas berbeza adalah sangat mudah, hanya gunakan kata kunci yang berbeza dalam pernyataan pilih. Sebagai contoh, berikut ialah penyataan pilih biasa: SELECTcolumn_name

See all articles