mirror of
https://github.com/sigmasternchen/php-doc-en
synced 2025-03-15 16:38:54 +00:00
113 lines
2.6 KiB
XML
113 lines
2.6 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<!-- $Revision$ -->
|
|
<sect1 xml:id="language.oop5.final" xmlns="http://docbook.org/ns/docbook">
|
|
<title>Final Keyword</title>
|
|
<para>
|
|
The final keyword prevents child classes from overriding a method or constant by
|
|
prefixing the definition with <literal>final</literal>. If the class
|
|
itself is being defined final then it cannot be extended.
|
|
</para>
|
|
<para>
|
|
<example>
|
|
<title>Final methods example</title>
|
|
<programlisting role="php">
|
|
<![CDATA[
|
|
<?php
|
|
class BaseClass {
|
|
public function test() {
|
|
echo "BaseClass::test() called\n";
|
|
}
|
|
|
|
final public function moreTesting() {
|
|
echo "BaseClass::moreTesting() called\n";
|
|
}
|
|
}
|
|
|
|
class ChildClass extends BaseClass {
|
|
public function moreTesting() {
|
|
echo "ChildClass::moreTesting() called\n";
|
|
}
|
|
}
|
|
// Results in Fatal error: Cannot override final method BaseClass::moreTesting()
|
|
?>
|
|
]]>
|
|
</programlisting>
|
|
</example>
|
|
</para>
|
|
<para>
|
|
<example>
|
|
<title>Final class example</title>
|
|
<programlisting role="php">
|
|
<![CDATA[
|
|
<?php
|
|
final class BaseClass {
|
|
public function test() {
|
|
echo "BaseClass::test() called\n";
|
|
}
|
|
|
|
// As the class is already final, the final keyword is redundant
|
|
final public function moreTesting() {
|
|
echo "BaseClass::moreTesting() called\n";
|
|
}
|
|
}
|
|
|
|
class ChildClass extends BaseClass {
|
|
}
|
|
// Results in Fatal error: Class ChildClass may not inherit from final class (BaseClass)
|
|
?>
|
|
]]>
|
|
</programlisting>
|
|
</example>
|
|
</para>
|
|
<para>
|
|
<example xml:id="language.oop5.final.example.php81">
|
|
<title>Final constants example as of PHP 8.1.0</title>
|
|
<programlisting role="php">
|
|
<![CDATA[
|
|
<?php
|
|
class Foo
|
|
{
|
|
final public const X = "foo";
|
|
}
|
|
|
|
class Bar extends Foo
|
|
{
|
|
public const X = "bar";
|
|
}
|
|
|
|
// Fatal error: Bar::X cannot override final constant Foo::X
|
|
?>
|
|
]]>
|
|
</programlisting>
|
|
</example>
|
|
</para>
|
|
|
|
<note>
|
|
<simpara>
|
|
Properties cannot be declared final: only classes, methods, and constants (as of PHP 8.1.0) may be declared as final.
|
|
</simpara>
|
|
<simpara>
|
|
As of PHP 8.0.0, private methods may not be declared final except for the constructor.
|
|
</simpara>
|
|
</note>
|
|
</sect1>
|
|
<!-- Keep this comment at the end of the file
|
|
Local variables:
|
|
mode: sgml
|
|
sgml-omittag:t
|
|
sgml-shorttag:t
|
|
sgml-minimize-attributes:nil
|
|
sgml-always-quote-attributes:t
|
|
sgml-indent-step:1
|
|
sgml-indent-data:t
|
|
indent-tabs-mode:nil
|
|
sgml-parent-document:nil
|
|
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
|
|
sgml-exposed-tags:nil
|
|
sgml-local-catalogs:nil
|
|
sgml-local-ecat-files:nil
|
|
End:
|
|
vim600: syn=xml fen fdm=syntax fdl=2 si
|
|
vim: et tw=78 syn=sgml
|
|
vi: ts=1 sw=1
|
|
-->
|