php-doc-en/language/oop5/paamayim-nekudotayim.xml
Etienne Kneuss 5ee8366690 Reverse dynamic static calls related DOC
git-svn-id: https://svn.php.net/repository/phpdoc/en/trunk@241268 c90b9560-bf6c-de11-be94-00142212c4b1
2007-08-15 15:41:29 +00:00

128 lines
3.1 KiB
XML

<?xml version="1.0" encoding="iso-8859-1"?>
<!-- $Revision: 1.10 $ -->
<sect1 xml:id="language.oop5.paamayim-nekudotayim" xmlns="http://docbook.org/ns/docbook">
<title>Scope Resolution Operator (::)</title>
<para>
The Scope Resolution Operator (also called Paamayim Nekudotayim) or in
simpler terms, the double colon, is a token that allows access to
<link linkend="language.oop5.static">static</link>,
<link linkend="language.oop5.constants">constant</link>, and overridden
members or methods of a class.
</para>
<para>
When referencing these items from outside the class definition, use
the name of the class.
</para>
<para>
Paamayim Nekudotayim would, at first, seem like a strange choice for
naming a double-colon. However, while writing the Zend Engine 0.5
(which powers PHP 3), that's what the Zend team decided to call it.
It actually does mean double-colon - in Hebrew!
</para>
<example>
<title>:: from outside the class definition</title>
<programlisting role="php">
<![CDATA[
<?php
class MyClass {
const CONST_VALUE = 'A constant value';
}
echo MyClass::CONST_VALUE;
?>
]]>
</programlisting>
</example>
<para>
Two special keywords <varname>self</varname> and <varname>parent</varname>
are used to access members or methods from inside the class definition.
</para>
<example>
<title>:: from inside the class definition</title>
<programlisting role="php">
<![CDATA[
<?php
class OtherClass extends MyClass
{
public static $my_static = 'static var';
public static function doubleColon() {
echo parent::CONST_VALUE . "\n";
echo self::$my_static . "\n";
}
}
OtherClass::doubleColon();
?>
]]>
</programlisting>
</example>
<para>
When an extending class overrides the parents definition of a method,
PHP will not call the parent's method. It's up to the extended class
on whether or not the parent's method is called. This also applies to <link
linkend="language.oop5.decon">Constructors and Destructors</link>, <link
linkend="language.oop5.overloading">Overloading</link>, and <link
linkend="language.oop5.magic">Magic</link> method definitions.
</para>
<example>
<title>Calling a parent's method</title>
<programlisting role="php">
<![CDATA[
<?php
class MyClass
{
protected function myFunc() {
echo "MyClass::myFunc()\n";
}
}
class OtherClass extends MyClass
{
// Override parent's definition
public function myFunc()
{
// But still call the parent function
parent::myFunc();
echo "OtherClass::myFunc()\n";
}
}
$class = new OtherClass();
$class->myFunc();
?>
]]>
</programlisting>
</example>
</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:"../../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
-->