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

В 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"
}