PHP8.1 new features explained Enums enumeration
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; }
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, ) {} }
In this example, creating an enum and passing it to aBlogPost looks like this:
$post = new BlogPost(Status::DRAFT);
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', }; } }
Methods can be used like this:
$status = Status::ARCHIVED; $status->color(); // 'red'
Static methods are also allowed:
enum Status { // … public static function make(): Status { // … } }
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', }; } }
#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 { /* … */ } }
# 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'; }
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; }
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'; // … }
#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
The enumeration can be restored from the value using: Enum::from
$status = Status::from(2); // Status::PUBLISHED
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
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 ] */
Please note that this array contains the actual enumeration objects:
array_map( fn(Status $status) => $status->color(), Status::cases() );
#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
# 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', // … ];
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!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



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.

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.

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~

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.

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.

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!

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.

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.
