|  | 
 
 match
  The matchexpression branches evaluation based on an
  identity check of a value.
  Similarly to aswitchstatement, amatchexpression has a subject expression that is
  compared against multiple alternatives. Unlikeswitch,
  it will evaluate to a value much like ternary expressions.
  Unlikeswitch, the comparison is an identity check
  (===) rather than a weak equality check (==).
  Match expressions are available as of PHP 8.0.0. 
  Example #1 Structure of a matchexpression 
<?php
$return_value = match (subject_expression) {
    single_conditional_expression => return_expression,
    conditional_expression1, conditional_expression2 => return_expression,
};
?>
 
   Example #2 Basic matchusage 
<?php
$food = 'cake';
$return_value = match ($food) {
    'apple' => 'This food is an apple',
    'bar' => 'This food is a bar',
    'cake' => 'This food is a cake',
};
var_dump($return_value);
?>
 The above example will output:
string(19) "This food is a cake"
 
   Example #3 Example of using matchwith comparison operators 
<?php
$age = 18;
$output = match (true) {
    $age < 2 => "Baby",
    $age < 13 => "Child",
    $age <= 19 => "Teenager",
    $age >= 40 => "Old adult",
    $age > 19 => "Young adult",
};
var_dump($output);
?>
 The above example will output: Note: 
   
    The result of a matchexpression does not need to be used.
 Note: 
   
    When a matchexpression is used as a standalone
    expression it must be terminated
    by a semicolon;.
 
  The matchexpression is similar to aswitchstatement but has some key differences: 
   
    
     A matcharm compares values strictly (===) instead
     of loosely as the switch statement does.
    
     A matchexpression returns a value.
    
     matcharms do not fall-through to later cases the wayswitchstatements do.
    
     A matchexpression must be exhaustive. 
  As switchstatements,matchexpressions are executed match arm by match arm.
  In the beginning, no code is executed.
  The conditional expressions are only evaluated if all previous conditional
  expressions failed to match the subject expression.
  Only the return expression corresponding to the matching conditional
  expression will be evaluated.
  For example: 
  matchexpression arms may contain multiple expressions
  separated by a comma.  That is a logical OR, and is a short-hand for multiple
  match arms with the same right-hand side. 
   
  A special case is the defaultpattern.
  This pattern matches anything that wasn't previously matched.
  For example: Note: 
   
    Multiple default patterns will raise a
    E_FATAL_ERRORerror.
 
  A matchexpression must be exhaustive.  If the
  subject expression is not handled by any match arm an
  UnhandledMatchError is thrown. 
  Example #4 Example of an unhandled match expression 
<?php
$condition = 5;
try {
    match ($condition) {
        1, 2 => foo(),
        3, 4 => bar(),
    };
} catch (\UnhandledMatchError $e) {
    var_dump($e);
}
?>
 The above example will output:
object(UnhandledMatchError)#1 (7) {
  ["message":protected]=>
  string(33) "Unhandled match value of type int"
  ["string":"Error":private]=>
  string(0) ""
  ["code":protected]=>
  int(0)
  ["file":protected]=>
  string(9) "/in/ICgGK"
  ["line":protected]=>
  int(6)
  ["trace":"Error":private]=>
  array(0) {
  }
  ["previous":"Error":private]=>
  NULL
}
 
  Using match expressions to handle non identity checks
   It is possible to use a matchexpression to handle
   non-identity conditional cases by usingtrueas the subject
   expression. 
   Example #5 Using a generalized match expressions to branch on integer ranges 
<?php
$age = 23;
$result = match (true) {
    $age >= 65 => 'senior',
    $age >= 25 => 'adult',
    $age >= 18 => 'young adult',
    default => 'kid',
};
var_dump($result);
?>
 The above example will output: 
   Example #6 Using a generalized match expressions to branch on string content 
<?php
$text = 'Bienvenue chez nous';
$result = match (true) {
    str_contains($text, 'Welcome'), str_contains($text, 'Hello') => 'en',
    str_contains($text, 'Bienvenue'), str_contains($text, 'Bonjour') => 'fr',
    // ...
};
var_dump($result);
?>
 The above example will output: |