is_a

オブジェクトが指定された型のものか、部分型であるかを調べる

説明

bool is_a(mixed $object_or_class, string $class, bool $allow_string = false)

指定した object_or_classclass オブジェクトの型であるか、 あるいは class が、 その上位型のひとつであるかを調べます。

パラメータ

object_or_class

調べたいクラス名、またはオブジェクトのインスタンス

class

クラスまたはインターフェイスの名前。

allow_string

このパラメータを false にすると、 クラス名を表す文字列を object_or_class に指定できなくなります。 そして、クラスが存在しない場合のオートローダーの呼び出しもしなくなります。

戻り値

object_or_classclass オブジェクトの型であるか、 あるいは class が、その上位型のひとつである場合に true、それ以外の場合に false を返します。

例1 is_a の例

<?php
// クラス定義
class WidgetFactory
{
  var $oink = 'moo';
}

// オブジェクトを作成します
$WF = new WidgetFactory();

if (is_a($WF, 'WidgetFactory')) {
  echo "はい、\$WF は WidgetFactory です\n";
}
?>

例2 instanceof 演算子の使用

<?php
if ($WF instanceof WidgetFactory) {
    echo 'はい、$WF は WidgetFactory です';
}
?>

参考

  • get_class
  • get_parent_class
  • is_subclass_of