Обзор перечислений

(PHP 8 >= 8.1.0)

Перечисления, или Enums, разрешают разработчику определять настраиваемый тип, который ограничен одним значением из дискретного числа возможных. Это может быть особенно полезно при определении модели предметной области, поскольку даёт «сделать неверные состояния недопустимыми».

Перечисления появляются во многих языках программирования с разным набором функций и операций. В PHP перечисления — это вид объектов. Сами перечисления — это классы, а все его возможные случаи — это объекты одного экземпляра этого класса. То есть варианты перечисления — допустимые объекты и их можно использовать везде, где можно использовать объект, включая проверки типов.

Самый популярный пример перечисления — встроенный логический тип, он перечисляем и допускает значения true и false. Перечисления разрешают разработчикам определять свои произвольно надёжные перечисления.

add a note

User Contributed Notes 1 note

up
-6
Hayley Watson
10 months ago
It's important to notice that the description here doesn't describe Enum values as being constants. Some languages, like C, C++, and C#, think of an enum as a list of named integers, and working with enums in those languages is just working with integers. PHP does not do that.

In the same way that PHP's booleans are their own type and not just constants with integer values 1 and 0, an Enum is its own type. It's not a bunch of integers (or strings) that have been given names, and shouldn't be thought of or used as such.

An Enum only needs to be backed by some primitive value like an integer or string if you need to communicate it outside the program (a message, UI, db storage, wire protocol, etc) where it has to be converted from/to its native PHP value (this is addressed again on the Backed Enumerations page). If you're converting back and forth between Enums and their backing values inside your own program to get anything done then you might be missing the point of Enums.

You might want more structure to your Enum than just a pure set of distinct but otherwise nondescript values (you might at least want them to be ordered). But all that carry-on should be encapsulated within the Enum class itself via additional methods.
To Top