- PHP 教程
- PHP - 首页
- PHP - 简介
- PHP - 安装
- PHP - 历史
- PHP - 特性
- PHP - 语法
- PHP - Hello World
- PHP - 注释
- PHP - 变量
- PHP - Echo/Print
- PHP - var_dump
- PHP - $ 和 $$ 变量
- PHP - 常量
- PHP - 魔术常量
- PHP - 数据类型
- PHP - 类型转换
- PHP - 类型混杂
- PHP - 字符串
- PHP - 布尔值
- PHP - 整数
- PHP - 文件与I/O
- PHP - 数学函数
- PHP - Heredoc & Nowdoc
- PHP - 复合类型
- PHP - 文件包含
- PHP - 日期与时间
- PHP - 标量类型声明
- PHP - 返回类型声明
- PHP 运算符
- PHP - 运算符
- PHP - 算术运算符
- PHP - 比较运算符
- PHP - 逻辑运算符
- PHP - 赋值运算符
- PHP - 字符串运算符
- PHP - 数组运算符
- PHP - 条件运算符
- PHP - 展开运算符
- PHP - 空值合并运算符
- PHP - 比较符
- PHP 控制语句
- PHP - 决策
- PHP - if…else 语句
- PHP - switch 语句
- PHP - 循环类型
- PHP - for 循环
- PHP - foreach 循环
- PHP - while 循环
- PHP - do…while 循环
- PHP - break 语句
- PHP - continue 语句
- PHP 函数
- PHP - 函数
- PHP - 函数参数
- PHP - 按值传递
- PHP - 按引用传递
- PHP - 默认参数
- PHP - 具名参数
- PHP - 可变参数
- PHP - 返回值
- PHP - 传递函数
- PHP - 递归函数
- PHP - 类型提示
- PHP - 变量作用域
- PHP - 严格类型
- PHP - 匿名函数
- PHP - 箭头函数
- PHP - 可变函数
- PHP - 局部变量
- PHP - 全局变量
- PHP 超全局变量
- PHP - 超全局变量
- PHP - $GLOBALS
- PHP - $_SERVER
- PHP - $_REQUEST
- PHP - $_POST
- PHP - $_GET
- PHP - $_FILES
- PHP - $_ENV
- PHP - $_COOKIE
- PHP - $_SESSION
- PHP 文件处理
- PHP - 文件处理
- PHP - 打开文件
- PHP - 读取文件
- PHP - 写入文件
- PHP - 文件是否存在
- PHP - 下载文件
- PHP - 复制文件
- PHP - 追加文件
- PHP - 删除文件
- PHP - 处理CSV文件
- PHP - 文件权限
- PHP - 创建目录
- PHP - 列出文件
- 面向对象PHP
- PHP - 面向对象编程
- PHP - 类和对象
- PHP - 构造函数和析构函数
- PHP - 访问修饰符
- PHP - 继承
- PHP - 类常量
- PHP - 抽象类
- PHP - 接口
- PHP - Traits
- PHP - 静态方法
- PHP - 静态属性
- PHP - 命名空间
- PHP - 对象迭代
- PHP - 封装
- PHP - final 关键字
- PHP - 重载
- PHP - 克隆对象
- PHP - 匿名类
- PHP Web开发
- PHP - Web 概念
- PHP - 表单处理
- PHP - 表单验证
- PHP - 表单邮件/URL
- PHP - 完整表单
- PHP - 文件包含
- PHP - GET & POST
- PHP - 文件上传
- PHP - Cookie
- PHP - Session
- PHP - Session 选项
- PHP - 发送邮件
- PHP - 输入过滤
- PHP - Post-Redirect-Get (PRG)
- PHP - 闪存消息
- PHP 高级
- PHP - MySQL
- PHP.INI 文件配置
- PHP - 数组解构
- PHP - 编码规范
- PHP - 正则表达式
- PHP - 错误处理
- PHP - try…catch
- PHP - 调试Bug
- PHP - 针对C开发者
- PHP - 针对PERL开发者
- PHP - 框架
- PHP - Core PHP vs 框架
- PHP - 设计模式
- PHP - 过滤器
- PHP - JSON
- PHP - 异常
- PHP - 特殊类型
- PHP - 散列
- PHP - 加密
- PHP - is_null() 函数
- PHP - 系统调用
- PHP - HTTP 认证
- PHP - 交换变量
- PHP - Closure::call()
- PHP - 过滤后的 unserialize()
- PHP - IntlChar
- PHP - CSPRNG
- PHP - 期望
- PHP - use 语句
- PHP - 整数除法
- PHP - 已弃用的特性
- PHP - 已移除的扩展和SAPI
- PHP - PEAR
- PHP - CSRF
- PHP - FastCGI 进程
- PHP - PDO 扩展
- PHP - 内置函数
- PHP 有用资源
- PHP - 速查表
- PHP - 问答
- PHP - 快速指南
- PHP - 在线编译器
- PHP - 有用资源
- PHP - 讨论
PHP - 严格类型
PHP 通常被认为是一种弱类型语言。在 PHP 中,无需在为变量赋值之前声明其类型。PHP 解析器会尽可能地将变量转换为兼容的类型。
例如,如果传递的值之一是数字的字符串表示,而第二个是数值变量,则 PHP 会将字符串变量转换为数值以执行加法运算。
示例
请看下面的例子:
<?php function addition($x, $y) { echo "First number: $x Second number: $y Addition: " . $x+$y; } $x="10"; $y=20; addition($x, $y); ?>
它将产生以下输出:
First number: 10 Second number: 20 Addition: 30
但是,如果上面例子中的$x是一个不包含有效数值表示的字符串,则会遇到错误。
<?php function addition($x, $y) { echo "First number: $x Second number: $y Addition: " . $x+$y; } $x="Hello"; $y=20; addition($x, $y); ?>
它将产生以下输出:
PHP Fatal error: Uncaught TypeError: Unsupported operand types: string + int in hello.php:5
类型提示
从 PHP 5.6 版本开始支持类型提示。这意味着您可以明确声明代码中声明的变量的预期类型。PHP 允许您对函数参数、返回值和类属性进行类型提示。通过这种方式,可以编写更健壮的代码。
让我们在上面的程序中的加法函数中加入类型提示:
function addition(int $x, int $y) { echo "First number: $x Second number: $y Addition: " . $x+$y; }
请注意,仅仅在变量声明中使用数据类型并不能阻止不匹配类型的异常,因为 PHP 是一种动态类型语言。换句话说,$x="10" 和 $y=20 仍然会得到 30 的结果,而 $x="Hello" 会导致解析器引发错误。
示例
<?php function addition($x, $y) { echo "First number: $x \n"; echo "Second number: $y \n"; echo "Addition: " . $x+$y . "\n\n"; } $x=10; $y=20; addition($x, $y); $x="10"; $y=20; addition($x, $y); $x="Hello"; $y=20; addition($x, $y); ?>
它将产生以下输出:
First number: 10 Second number: 20 Addition: 30 First number: 10 Second number: 20 Addition: 30 First number: Hello Second number: 20 PHP Fatal error: Uncaught TypeError: Unsupported operand types: string + int in hello.php:5
strict_types
PHP 可以强制执行更严格的类型转换规则,这样 "10" 就不会隐式转换为 10。这可以通过在 declare() 语句中将strict_types指令设置为 1 来强制执行。
declare() 语句必须是 PHP 代码中的第一条语句,紧跟在 "<?php" 标签之后。
示例
请看下面的例子:
<?php declare (strict_types=1); function addition(int $x, int $y) { echo "First number: $x Second number: $y Addition: " . $x+$y; } $x=10; $y=20; addition($x, $y); ?>
它将产生以下输出:
First number: 10 Second number: 20 Addition: 30
现在,如果$x设置为 "10",则不会进行隐式转换,从而导致以下错误:
PHP Fatal error: Uncaught TypeError: addition(): Argument #1 ($x) must be of type int, string given
从 PHP 7 开始,类型提示支持已扩展到函数返回值,以防止出现意外的返回值。您可以通过在参数列表之后添加预期类型,并在其前面加上冒号 (:) 符号来对返回值进行类型提示。
示例
让我们在下面的 division() 函数的返回值中添加类型提示。
<?php declare (strict_types=1); function division(int $x, int $y) : int { return $x/$y; } $x=10; $y=20; $result = division($x, $y); echo "First number: $x Second number: $y Addition: " . $result; ?>
由于函数返回 0.5,它不是int类型(即函数返回值使用的类型提示),因此会显示以下错误:
Fatal error: Uncaught TypeError: division(): Return value must be of type int, float returned in hello.php:5