php8 match表达式使用教程

简介

PHP 8 引入了 match() 表达式,用来替代传统的 switch 语句,提供更简洁、更安全的方式进行条件匹配。与 switch 不同,match() 是一个表达式,它会返回值,并且使用 严格比较(===)。

基本语法

php 复制代码
$result = match (表达式) {
    值1 => 结果1,
    值2 => 结果2,
    值3, 值4 => 结果3, // 多个值匹配同一个结果
    default => 默认结果
};

match() 直接返回值,并且必须匹配到一个值,否则会抛出 UnhandledMatchError

match() VS switch()

特性 switch match
语法 需要 casebreak 直接使用 =>
比较方式 宽松比较 (==) 严格比较 (===)
返回值 需要 return 直接返回值
fall-through 可能(如果缺少 break 不会(默认不会执行下一个 case
未匹配情况 不会抛异常 会抛异常

match() 的基本用法

基本示例

php 复制代码
$number = 2;

$result = match ($number) {
    1 => 'One',
    2 => 'Two',
    3 => 'Three',
    default => 'Unknown'
};

echo $result; // 输出 "Two"
  • match() 自动返回值,不需要 return

  • 严格比较,2 == "2"switch 里会匹配,但在 match() 里不会

多个值匹配同一个结果

php 复制代码
$fruit = "apple";

$color = match ($fruit) {
    "apple", "cherry", "strawberry" => "red",
    "banana", "lemon" => "yellow",
    "grape", "blueberry" => "purple",
    default => "unknown"
};

echo $color; // 输出 "red"
  • 可以在 match() 的 单个 case 里写多个匹配值

严格比较 (===)

php 复制代码
$value = "2";

$result = match ($value) {
    2 => "Matched as integer",
    "2" => "Matched as string",
    default => "No match"
};

echo $result; // 输出 "Matched as string"
  • match() 严格比较 (===),不会把 "2" 误认为 2

变量匹配

php 复制代码
$input = 100;

$result = match ($input) {
    $a = 10 => "Ten",
    $b = 100 => "Hundred",
    default => "Other"
};

echo $result; // 输出 "Hundred"
  • match() 支持 变量赋值($a = 10),但是 $a 不能在 match() 外使用。

match() 结合表达式

match() 结合函数

php 复制代码
function getCategory(string $food): string {
    return match ($food) {
        "apple", "banana", "cherry" => "Fruit",
        "carrot", "potato" => "Vegetable",
        default => "Unknown"
    };
}

echo getCategory("apple"); // 输出 "Fruit"
  • match() 可以直接用在函数返回值,使代码更清晰。

match() 结合数组

php 复制代码
$code = 404;

$messages = [
    200 => "OK",
    301 => "Moved Permanently",
    404 => "Not Found",
    500 => "Internal Server Error"
];

$message = match ($code) {
    default => $messages[$code] ?? "Unknown Status"
};

echo $message; // 输出 "Not Found"
  • match() 可以结合数组 实现动态映射

match() 结合 throw

php 复制代码
$role = "guest";

$permission = match ($role) {
    "admin" => "Access All",
    "editor" => "Edit Content",
    "user" => "View Content",
    default => throw new Exception("Invalid role: $role")
};

echo $permission;
  • match() 可以直接抛出异常,增强安全性。

match() 进阶用法

match() 结合 fn()(箭头函数)

php 复制代码
$input = "php";

$result = fn() => match ($input) {
    "php" => "Hypertext Preprocessor",
    "js" => "JavaScript",
    default => "Unknown"
};

echo $result(); // 输出 "Hypertext Preprocessor"
  • match() 可以结合箭头函数 fn(),使代码更加简洁。

match() 结合 true 模拟 switch 的 case 逻辑

php 复制代码
$age = 25;

$category = match (true) {
    $age < 18 => "Minor",
    $age >= 18 && $age < 60 => "Adult",
    default => "Senior"
};

echo $category; // 输出 "Adult"
  • 这样可以避免 switch(true) 的写法,让 match() 处理 范围匹配。

match() 的错误和注意点

必须匹配到一个值

php 复制代码
$value = 5;

$result = match ($value) {
    1 => "One",
    2 => "Two",
    3 => "Three"
};

echo $result;

错误:Uncaught UnhandledMatchError: Unhandled match case '5'

解决方法:加上 default

php 复制代码
$result = match ($value) {
    1 => "One",
    2 => "Two",
    3 => "Three",
    default => "Unknown"
};
相关推荐
BingoGo1 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php
JaguarJack1 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php·服务端
BingoGo2 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php
JaguarJack2 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php·服务端
JaguarJack3 天前
推荐 PHP 属性(Attributes) 简洁读取 API 扩展包
后端·php·服务端
BingoGo3 天前
推荐 PHP 属性(Attributes) 简洁读取 API 扩展包
php
JaguarJack4 天前
告别 Laravel 缓慢的 Blade!Livewire Blaze 来了,为你的 Laravel 性能提速
后端·php·laravel
郑州光合科技余经理5 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
QQ5110082855 天前
python+springboot+django/flask的校园资料分享系统
spring boot·python·django·flask·node.js·php
WeiXin_DZbishe5 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5