mirror of
https://github.com/php/doc-ja.git
synced 2026-03-27 08:32:09 +01:00
166 lines
4.6 KiB
XML
166 lines
4.6 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<!-- $Revision$ -->
|
|
<!-- EN-Revision: 888507ca9ed7a8517edbf2d00a64fcaf5865aa23 Maintainer: takagi Status: ready -->
|
|
<!-- CREDITS: hirokawa,shimooka,mumumu -->
|
|
|
|
<sect1 xml:id="language.oop5.static" xmlns="http://docbook.org/ns/docbook">
|
|
<title>static キーワード</title>
|
|
|
|
<tip>
|
|
<simpara>
|
|
このページでは、<literal>static</literal>
|
|
キーワードを使って static メソッド や
|
|
static プロパティを定義する方法を説明します。
|
|
<literal>static</literal> は、
|
|
<link linkend="language.variables.scope.static">static 変数</link>
|
|
や <link linkend="functions.anonymous-functions.static">static な無名関数</link>、そして
|
|
<link linkend="language.oop5.late-static-bindings">遅延静的束縛</link>
|
|
にも使えます。これらの場合の <literal>static</literal> の使い方は、
|
|
それぞれのページを参照ください。
|
|
</simpara>
|
|
</tip>
|
|
|
|
<para>
|
|
クラスプロパティもしくはメソッドを static として宣言することで、
|
|
クラスのインスタンス化の必要なしにアクセスすることができます。
|
|
static として宣言されたプロパティやメソッドは、
|
|
インスタンス化されたオブジェクトの内部からも :: (スコープ定義演算子) を使ってコールできます。
|
|
</para>
|
|
|
|
<sect2 xml:id="language.oop5.static.methods">
|
|
<title>static メソッド</title>
|
|
|
|
<para>
|
|
static メソッドはオブジェクトのインスタンスを生成せずに
|
|
コールすることができるので、疑似変数 <varname>$this</varname> は、
|
|
static として宣言されたメソッドの内部から利用することはできません。
|
|
</para>
|
|
|
|
<warning>
|
|
<para>
|
|
static でないメソッドをstaticメソッドとしてコールすると、
|
|
<classname>Error</classname> がスローされます。
|
|
</para>
|
|
<para>
|
|
PHP 8.0.0 より前のバージョンでは、
|
|
static でないメソッドをstaticメソッドとしてコールすることが非推奨になっており、
|
|
<constant>E_DEPRECATED</constant> レベルの警告が発生していました。
|
|
</para>
|
|
</warning>
|
|
|
|
<example>
|
|
<title>static メソッドの例</title>
|
|
<programlisting role="php">
|
|
<![CDATA[
|
|
<?php
|
|
class Foo {
|
|
public static function aStaticMethod() {
|
|
// ...
|
|
}
|
|
}
|
|
|
|
Foo::aStaticMethod();
|
|
$classname = 'Foo';
|
|
$classname::aStaticMethod();
|
|
?>
|
|
]]>
|
|
</programlisting>
|
|
</example>
|
|
</sect2>
|
|
|
|
<sect2 xml:id="language.oop5.static.properties">
|
|
<title>static プロパティ</title>
|
|
|
|
<para>
|
|
static プロパティは、
|
|
<link linkend="language.oop5.paamayim-nekudotayim">スコープ定義演算子</link>
|
|
を使ってアクセスできますが、
|
|
オブジェクト演算子 (<literal>-></literal>) を使ってアクセスすることはできません。
|
|
</para>
|
|
|
|
<para>
|
|
変数を用いてクラスを参照することも可能です。
|
|
変数の値に (<literal>self</literal> や <literal>parent</literal>、
|
|
<literal>static</literal> といった)
|
|
キーワードを指定することはできません。
|
|
</para>
|
|
|
|
<example>
|
|
<title>static プロパティの例</title>
|
|
<programlisting role="php">
|
|
<![CDATA[
|
|
<?php
|
|
class Foo
|
|
{
|
|
public static $my_static = 'foo';
|
|
|
|
public function staticValue() {
|
|
return self::$my_static;
|
|
}
|
|
}
|
|
|
|
class Bar extends Foo
|
|
{
|
|
public function fooStatic() {
|
|
return parent::$my_static;
|
|
}
|
|
}
|
|
|
|
|
|
print Foo::$my_static . "\n";
|
|
|
|
$foo = new Foo();
|
|
print $foo->staticValue() . "\n";
|
|
print $foo->my_static . "\n"; // Undefined "Property" my_static
|
|
|
|
print $foo::$my_static . "\n";
|
|
$classname = 'Foo';
|
|
print $classname::$my_static . "\n";
|
|
|
|
print Bar::$my_static . "\n";
|
|
$bar = new Bar();
|
|
print $bar->fooStatic() . "\n";
|
|
?>
|
|
]]>
|
|
</programlisting>
|
|
&example.outputs.8.similar;
|
|
<screen>
|
|
<![CDATA[
|
|
foo
|
|
foo
|
|
|
|
Notice: Accessing static property Foo::$my_static as non static in /in/V0Rvv on line 23
|
|
|
|
Warning: Undefined property: Foo::$my_static in /in/V0Rvv on line 23
|
|
|
|
foo
|
|
foo
|
|
foo
|
|
foo
|
|
]]>
|
|
</screen>
|
|
</example>
|
|
</sect2>
|
|
</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
|
|
-->
|