1
0
mirror of https://github.com/php/doc-ja.git synced 2026-03-27 08:32:09 +01:00
Files
archived-doc-ja/language/oop5/static.xml
2025-08-28 19:57:49 +09:00

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>-&gt;</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
-->