Константы классов

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

Замечание:

Дочерним классам разрешается переопределять константы родительского класса. Начиная с PHP 8.1.0 константы окончательного класса, который определили с ключевым словом final, нельзя переопределить дочерним классом.

Интерфейсам также разрешается содержать константы. Примеры интерфейсных констант приводит документация по интерфейсам.

К классу возможно обратиться через переменную. Ключевые слова наподобие self, parent и static нельзя указывать как значения переменной, которая ссылается на класс.

Обратите внимание, что константы класса выделяются один раз для каждого класса, а не отдельно для каждого экземпляра класса.

Начиная с PHP 8.3.0 константы классов поддерживают объявление скалярного типа: bool, int, float, string или даже array. В значении константы с типом array указывают только другие скалярные типы.

Пример #1 Объявление константы и обращение к константе

<?php

class MyClass
{
    const CONSTANT = 'значение константы';

    function showConstant() {
        echo  self::CONSTANT . "\n";
    }
}

echo MyClass::CONSTANT . "\n";

$classname = "MyClass";
echo $classname::CONSTANT . "\n";

$class = new MyClass();
$class->showConstant();

echo $class::CONSTANT . "\n";

?>

Специальная константа ::class на этапе компиляции разрешает имена классов в абсолютные. Это полезно при работе в классах с пространством имён.

Пример #2 Пример поведения константы ::class в классе с пространством имён

<?php

namespace foo
{
    class bar {}

    echo bar::class; // foo\bar
}

?>

Пример #3 Пример константного выражения класса

<?php

const ONE = 1;

class foo
{
    const TWO = ONE * 2;
    const THREE = ONE + self::TWO;
    const SENTENCE = 'Значение константы THREE - ' . self::THREE;
}

?>

Пример #4 Модификаторы видимости констант класса начиная с PHP 7.1.0

<?php

class Foo
{
    public const BAR = 'bar';
    private const BAZ = 'baz';
}

echo Foo::BAR, PHP_EOL;
echo Foo::BAZ, PHP_EOL;

?>

Результат выполнения приведённого примера в PHP 7.1:

bar

Fatal error: Uncaught Error: Cannot access private const Foo::BAZ in …

Замечание:

Начиная с PHP 7.1.0 для констант класса разрешается указывать модификаторы области видимости.

Пример #5 Проверка вариантности видимости констант класса начиная с PHP 8.3.0

<?php

interface MyInterface
{
    public const VALUE = 42;
}

class MyClass implements MyInterface
{
    protected const VALUE = 42;
}

?>

Результат выполнения приведённого примера в PHP 8.3:

Fatal error: Access level to MyClass::VALUE must be public (as in interface MyInterface) …

Замечание: Начиная с PHP 8.3.0 вариантность видимости проверяется строже. До этой версии видимость константы класса могла не совпадать с видимостью константы реализованного интерфейса.

Пример #6 Синтаксис получения константы класса начиная с PHP 8.3.0

<?php

class Foo
{
    public const BAR = 'bar';
    private const BAZ = 'baz';
}

$name = 'BAR';
echo Foo::{$name}, PHP_EOL; // bar

?>

Замечание:

Начиная с PHP 8.3.0 значения констант класса разрешили получать динамически, через переменную.

Пример #7 Назначение типов константам классов начиная с PHP 8.3.0

<?php

class MyClass
{
    public const bool MY_BOOL = true;
    public const int MY_INT = 1;
    public const float MY_FLOAT = 1.01;
    public const string MY_STRING = 'one';
    public const array MY_ARRAY = [self::MY_BOOL, self::MY_INT, self::MY_FLOAT, self::MY_STRING];
}

var_dump(MyClass::MY_BOOL);
var_dump(MyClass::MY_INT);
var_dump(MyClass::MY_FLOAT);
var_dump(MyClass::MY_STRING);
var_dump(MyClass::MY_ARRAY);

?>

Результат выполнения приведённого примера в PHP 8.3:

bool(true)
int(1)
float(1.01)
string(3) "one"
array(4) {
  [0]=>
  bool(true)
  [1]=>
  int(1)
  [2]=>
  float(1.01)
  [3]=>
  string(3) "one"
}