Константы классов
В 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"
}