PHPerKaigi 2025

Grundlagen der Aufzählungen

Enums sind ähnlich wie Klassen und teilen sich die gleichen Namensräume wie Klassen, Schnittstellen und Traits. Sie können auch auf die gleiche Weise automatisch geladen werden. Eine Enum definiert einen neuen Typ, der eine feste, begrenzte Anzahl von möglichen zulässigen Werten hat.

<?php
enum Suit
{
case
Hearts;
case
Diamonds;
case
Clubs;
case
Spades;
}
?>

Diese Deklaration erzeugt einen neuen Aufzählungstyp namens Suit, der genau vier zulässige Werte hat: Suit::Hearts, Suit::Diamonds, Suit::Clubs, und Suit::Spades. Variablen kann einer dieser zulässigen Werte zugewiesen werden. Eine Funktion kann gegen einen Aufzählungstyp typgeprüft werden; in diesem Fall dürfen nur Werte dieses Typs übergeben werden.

<?php

function pick_a_card(Suit $suit)
{
/* ... */
}

$val = Suit::Diamonds;

// OK
pick_a_card($val);

// OK
pick_a_card(Suit::Clubs);

// TypeError: pick_a_card(): Argument #1 ($suit) must be of type Suit, string given
pick_a_card('Spades');
?>

Eine Aufzählung kann null oder mehr case-Definitionen haben, wobei es kein Maximum gibt. Eine Aufzählung mit null Fällen ist zwar syntaktisch gültig, aber ziemlich nutzlos.

Für Aufzählungsfälle gelten die gleichen Syntaxregeln wie für jedes Label in PHP, siehe Konstanten.

Standardmäßig werden Fälle intern nicht mit einem skalaren Wert verknüpft. Das bedeutet, dass Suit::Hearts nicht gleich "0" ist. Stattdessen wird jeder Fall mit einem Singleton-Objekt mit diesem Namen verknüpft. Der folgende Code veranschaulicht dies:

<?php

$a
= Suit::Spades;
$b = Suit::Spades;

$a === $b; // true

$a instanceof Suit; // true
?>

Es bedeutet auch, dass Enum-Werte niemals < oder > sind, da diese Vergleiche bei Objekten keinen Sinn ergeben. Wenn Enum-Werte auf diese Weise verglichen werden, wird immer false zurückgegeben.

Eine solche Art von Fall, der keine zugehörigen Daten enthält, wird als "Pure Case" (reiner Fall) bezeichnet. Eine Enum, die nur reine Fälle enthält, wird als "Pure Enum" bezeichnet.

Alle Pure Cases werden als Instanzen ihres Enum-Typs implementiert. Der Enum-Typ wird intern als Klasse dargestellt.

Alle Fälle haben die schreibgeschützte Eigenschaft name, die den Namen des Falls selbst angibt, wobei zwischen Groß- und Kleinschreibung unterschieden wird.

<?php

print Suit::Spades->name;
// Gibt "Spades" aus
?>

Wenn der Name eines Enum-Falls dynamisch ermittelt wird, ist es auch möglich, die Funktionen defined() und constant() zu verwenden, um zu prüfen, ob es den Enum-Fall gibt, bzw. diesen auszulesen. Davon wird jedoch abgeraten, da die Verwendung von Wertgebundene Aufzählungen (Backed Enums) die meisten Anwendungsfälle abdecken sollte.

add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top