オブジェクトインターフェイスにより、あるクラスが実装する必要があるメソッドの 種類を、これらのメソッドの実体を定義することなく、指定するコードを作成できる ようになります。
インターフェイスはキーワードinterfaceにより定義され、通常のクラスと 同様に定義することができますが、メソッドの実装は全く定義されません。
インターフェイス内で宣言される全てのメソッドはpublicである必要があります。 これは、インターフェイスの特性によります。
インターフェイスを実装するには、implements 演算子を使用し、 このインターフェイスに含まれる全てのメソッドを実装する必要があります。 実装されていない場合、致命的エラーとなります。 各インターフェイスをカンマで区切って指定することで、 クラスは複数のインターフェイスを実装することができます。
注意: ひとつのクラスの中で、同じ名前の関数を含む 2 つのインターフェイスを 実装することはできません。あいまいさを解決できなくなるためです。
注意: クラスと同様、インターフェイスも extend 演算子で継承することができます。
インターフェイスに定数を持たせることもできます。 インターフェイス定数は クラス定数 とまったく同じように動作します。 また、それを継承したクラスやインターフェイスで上書きすることはできません。
例1 Interface の例
<?php
// インターフェイス 'iTemplate' を宣言する
interface iTemplate
{
public function setVariable($name, $var);
public function getHtml($template);
}
// インターフェイスを実装する。
// これは動作します。
class Template implements iTemplate
{
private $vars = array();
public function setVariable($name, $var)
{
$this->vars[$name] = $var;
}
public function getHtml($template)
{
foreach($this->vars as $name => $value) {
$template = str_replace('{' . $name . '}', $value, $template);
}
return $template;
}
}
// これは動作しません。
// Fatal error: Class BadTemplate contains 1 abstract methods
// and must therefore be declared abstract (iTemplate::getHtml)
class BadTemplate implements iTemplate
{
private $vars = array();
public function setVariable($name, $var)
{
$this->vars[$name] = $var;
}
}
?>
例2 インターフェイスの継承
<?php
interface a
{
public function foo();
}
interface b extends a
{
public function baz(Baz $baz);
}
// これは動作します
class c implements b
{
public function foo()
{
}
public function baz(Baz $baz)
{
}
}
// これは動作せず、fatal error となります
class d implements b
{
public function foo()
{
}
public function baz(Foo $foo)
{
}
}
?>
例3 複数のインターフェイスの継承
<?php
interface a
{
public function foo();
}
interface b
{
public function bar();
}
interface c extends a, b
{
public function baz();
}
class d implements c
{
public function foo()
{
}
public function bar()
{
}
public function baz()
{
}
}
?>
例4 インターフェイスでの定数
<?php
interface a
{
const b = 'Interface constant';
}
// Interface constant と表示します
echo a::b;
// しかし、これは動作しません。定数のオーバーライドが
// できないからです。これはクラス定数と同じことです。
class b implements a
{
const b = 'Class constant';
}
?>
instanceof 演算子も参照ください。