Home Backend Development PHP8 PHP8.1 new features explained Enums enumeration

PHP8.1 new features explained Enums enumeration

Nov 10, 2021 pm 03:09 PM
php8

This article is a translation, original address: https://stitcher.io/blog/php-enums

PHP 8.1: Enumerations

They're finally here - built-in support for enums will be added in PHP 8.1! Some may think they should have done this a long time ago, but you didn't hear my complaint; I'm glad they did! This article is dedicated to a deep dive into the newly added features.

As usual in my PHP feature posts, we start with a high-level overview of what enumerations look like:

enum Status
{
    case DRAFT;
    case PUBLISHED;
    case ARCHIVED;
}
Copy after login

The benefit of enumerations is that they represent a set of constant values, but The most important thing is that these values ​​can be typed like this:

class BlogPost
{
    public function __construct(
        public Status $status, 
    ) {}
}
Copy after login

In this example, creating an enum and passing it to aBlogPost looks like this:

$post = new BlogPost(Status::DRAFT);
Copy after login

That's it The basics, as you can see, they are not complicated at all. While there are a lot of side notes to make, let’s take a deeper look at enumerations!

#Enumeration methods

Enumerations can define methods, just like classes. This is a very powerful feature, especially when combined with the match operator:

enum Status
{
    case DRAFT;
    case PUBLISHED;
    case ARCHIVED;
    
    public function color(): string
    {
        return match($this) 
        {
            Status::DRAFT => 'grey',   
            Status::PUBLISHED => 'green',   
            Status::ARCHIVED => 'red',   
        };
    }
}
Copy after login

Methods can be used like this:

$status = Status::ARCHIVED;
$status->color(); // 'red'
Copy after login

Static methods are also allowed:

enum Status
{
    // …
    
    public static function make(): Status
    {
        // …
    }
}
Copy after login

You can also use self in an enumeration:

enum Status
{
    // …
    
    public function color(): string
    {
        return match($this) 
        {
            self::DRAFT => 'grey',   
            self::PUBLISHED => 'green',   
            self::ARCHIVED => 'red',   
        };
    }
}
Copy after login

#Enumeration interface

Enumerations can implement interfaces, just like ordinary classes:

interface HasColor
{
    public function color(): string;
}
enum Status implements HasColor
{
    case DRAFT;
    case PUBLISHED;
    case ARCHIVED;
    
    public function color(): string { /* … */ }
}
Copy after login

# Enumeration values ​​- aka "backed enums"

Enumeration values ​​are represented internally by objects, but you can assign values ​​to them as needed; this is useful for e.g. it works. Serialize them into the database.

enum Status: string
{
    case DRAFT = 'draft';
    case PUBLISHED = 'published';
    case ARCHIVED = 'archived';
}
Copy after login

Pay attention to the type declaration in the enumeration definition. It indicates that all enumeration values ​​belong to the given type. You can also make it an int. Note that onlyint and string are allowed as enumeration values.

enum Status: int
{
    case DRAFT = 1;
    case PUBLISHED = 2;
    case ARCHIVED = 3;
}
Copy after login

The technical term for type enums is called "backed enumerations" because they are "backed" by simpler values. If you decide to assign an enumeration value, all cases should have a value. You can't mix and match them. Enumerations without "backing" are called "pure enumerations".

#Supported enumerations with interfaces

If you use a supported enumeration with an interface, the enumeration type must come directly after the enumeration name, implements before the keyword.

enum Status: string implements HasColor
{
    case DRAFT = 'draft';
    case PUBLISHED = 'published';
    case ARCHIVED = 'archived';
    
    // …
}
Copy after login

#Serialization supported enums

If you are assigning values ​​to enum cases, you may need a way to serialize and deserialize them . Serializing them means you need a way to access the enum values. This is done via a read-only public property:

$value = Status::PUBLISHED->value; // 2
Copy after login

The enumeration can be restored from the value using: Enum::from

$status = Status::from(2); // Status::PUBLISHED
Copy after login

If an unknown value is passed tryFrom, there is also a return null. There is an exception if you use from.

$status = Status::from('unknown'); // ValueError
$status = Status::tryFrom('unknown'); // null
Copy after login

Please note that you can also use the built-in serialize and unserialize functions on enumerations. Additionally, you can use json_encode with a supported enumeration and the result will be an enumeration value. This behavior can be overridden by implementing JsonSerializable.

#Listing enumeration values

You can get a list of all available cases in an enumeration using the static method: Enum::cases()

Status::cases();
/* [
    Status::DRAFT, 
    Status::PUBLISHED, 
    Status::ARCHIVED
] */
Copy after login

Please note that this array contains the actual enumeration objects:

array_map(
    fn(Status $status) => $status->color(), 
    Status::cases()
);
Copy after login

#Enumerations are objects

I already mentioned that enumeration values ​​are represented as objects, actual Above they are singleton objects. This means you can compare to them like this:

$statusA = Status::PENDING;
$statusB = Status::PENDING;
$statusC = Status::ARCHIVED;
$statusA === $statusB; // true
$statusA === $statusC; // false
$statusC instanceof Status; // true
Copy after login

# Enums as Array Keys

Since enum values ​​are actually objects, there is currently no way to They are used as array keys. The following will result in an error:

$list = [
    Status::DRAFT => 'draft',
    // …
];
Copy after login

There is an RFC to change this behavior, but it has not been voted on yet.

This means you can only use enums as keys in SplObjectStorage and WeakMaps.

#Traits

Enumerations can use traits just like classes, but with more restrictions. Overriding built-in enumeration methods is not allowed, and they cannot contain class attributes - their use in enumerations is prohibited.

#Reflection and Properties

As expected, a few reflection classes have been added to handle enumerations: ReflectionEnum, ReflectionEnumUnitCase and ReflectionEnumBackedCase. There is also a new enum_exists function, which does exactly what its name suggests.

Just like ordinary classes and attributes, enumerations and their cases can be annotated using attributes. Note that the TARGET_CLASS filter will also include enumerations.

One last thing: the enumeration also has a read-only attribute, which the RFC mentions is an implementation detail and should only be used for debugging purposes. But it's still worth mentioning. $enum->name

The above is the detailed content of PHP8.1 new features explained Enums enumeration. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What is the difference between php5 and php8 What is the difference between php5 and php8 Sep 25, 2023 pm 01:34 PM

The differences between php5 and php8 are in terms of performance, language structure, type system, error handling, asynchronous programming, standard library functions and security. Detailed introduction: 1. Performance improvement. Compared with PHP5, PHP8 has a huge improvement in performance. PHP8 introduces a JIT compiler, which can compile and optimize some high-frequency execution codes, thereby improving the running speed; 2. Improved language structure, PHP8 introduces some new language structures and functions. PHP8 supports named parameters, allowing developers to pass parameter names instead of parameter order, etc.

How to add mysql extension to php8 How to add mysql extension to php8 Oct 07, 2023 pm 03:31 PM

The steps to add mysql extension to php8 are: 1. Install the MySQL client library; 2. Install the development tools for PHP 8; 3. Download the MySQL extension source code; 4. Compile and install the MySQL extension; 5. Enable the MySQL extension; 6. Restart Just a web server.

Detailed graphic explanation of the installation and configuration method of apache2.4+php8.0 Detailed graphic explanation of the installation and configuration method of apache2.4+php8.0 Dec 06, 2022 pm 04:53 PM

This article will introduce to you how to install apache2.4 and how to configure php8.0. The article is accompanied by pictures and detailed steps. Let's take a look at how to install and configure apache2.4+php8.0~

How to connect to the database in php8 How to connect to the database in php8 Nov 16, 2023 pm 02:41 PM

PHP8 can use mysqli and PDO to connect to the database. Detailed introduction: 1. Use mysqli to connect to the database by passing in the database server name, user name, password and database name to connect. Then, use the `connect_error` attribute to check whether the connection is successful and output an error message if the connection fails. Finally, close the connection by calling the `close()` method; 2. Use PDO to connect to the database, and connect by passing in the database server name, password and database name, etc.

How to convert php8 data types How to convert php8 data types Nov 16, 2023 pm 02:51 PM

The methods of the php8 data type include converting strings to integers, converting integers to strings, converting strings to floating point numbers, converting floating point numbers to strings, converting arrays to strings, converting strings to arrays, and converting Boolean values ​​to integers. Integer conversion to Boolean value and variable type determination and conversion. Detailed introduction: 1. Converting a string to an integer includes the intval() function and (int) forced type conversion; 2. Converting an integer to a string includes the strval() function and (string) forced type conversion; 3. Converting a string to a float Points and so on.

An in-depth look at JIT in PHP 8 An in-depth look at JIT in PHP 8 Apr 25, 2022 pm 08:46 PM

This article will take you through the JIT in PHP 8 and talk about how JIT participates in the interpretation process. I hope it will be helpful to everyone!

What performance improvements does php8 have? What performance improvements does php8 have? Dec 21, 2023 pm 02:44 PM

The improved performance of php8 includes: 1. Introduction of JIT compiler; 2. Optimization of function calls; 3. Improvement of garbage collection mechanism; 4. Improvement of type system; 5. New language features; 6. Optimized string processing; 7. Improve array processing; 8. Introduce a new memory management mechanism; 9. Optimize code generation. Detailed introduction: 1. The introduction of the JIT compiler. PHP8 introduces the JIT compiler, which is a dynamic compilation technology that can convert PHP code into machine code for more efficient execution; 2. Optimization of function calls, etc.

What features does php8 have? What features does php8 have? Dec 21, 2023 pm 02:54 PM

Features of php8: 1. JIT compiler; 2. Named parameters; 3. Union types; 4. Annotations; 5. Constructor attribute enhancement; 6. Match expression; 7. nullsafe operator; 8. Improved type system; 9 , Error handling improvements; 10. Consistency improvements. Detailed introduction: 1. JIT compiler, PHP8 introduces just-in-time compilation technology, which compiles PHP code into native machine code, thereby improving the execution speed of the program; 2. Named parameters, PHP8 supports named parameters, allowing the use of parameter names when calling functions. etc.

See all articles