is_subclass_of

関数の概要

PHPの is_subclass_of 関数は、あるクラスが別のクラスを継承しているか(サブクラスか)どうかを判定するための関数です。オブジェクト指向プログラミングで継承関係を確認したい場合に便利で、親クラスとの関係性を動的にチェックできます。

パラメータの説明

  • object|string $object_or_string:調べたいオブジェクトのインスタンス、またはクラス名の文字列を指定します。
  • string $class_name:親クラス名を文字列で指定します。サブクラスかどうかを判定する基準となるクラスです。
  • bool $allow_string(省略可能):オブジェクトではなく文字列でクラス名を渡した場合に、そのクラス名に対しても判定を行うかどうか。デフォルトは false です。

戻り値

is_subclass_of は論理値(boolean)を返します。
指定したクラスが、第二引数で指定したクラスの子孫(直接・間接的なサブクラス)であれば true、そうでなければ false を返します。

使用例

基本的な使い方

<?php
class ParentClass {}
class ChildClass extends ParentClass {}

$child = new ChildClass();

var_dump(is_subclass_of($child, 'ParentClass')); // bool(true)
var_dump(is_subclass_of($child, 'NonExistentClass')); // bool(false)
?>

この例では、ChildClassParentClass を継承しているため、trueが返ります。

クラス名(文字列)を直接渡す例

<?php
class A {}
class B extends A {}

var_dump(is_subclass_of('B', 'A')); // bool(true)
var_dump(is_subclass_of('A', 'B')); // bool(false)
?>

オブジェクトではなくクラス名の文字列を渡す時は、第三引数を true に設定しない限り、false が返ることが多いので注意が必要です(PHPのバージョンによって振る舞いが異なる場合あり)。

allow_stringオプションを使う例

<?php
class Base {}
class Sub extends Base {}

var_dump(is_subclass_of('Sub', 'Base', true));  // bool(true)
var_dump(is_subclass_of('Base', 'Sub', true));  // bool(false)
?>

第三引数に true を渡すことで、文字列として渡したクラス名に対しても継承関係の判定ができます。

関連する関数

  • instanceof 演算子:オブジェクトが特定のクラスのインスタンスかどうかを判定する
  • get_parent_class():指定したクラスの親クラス名を取得する
  • is_a():オブジェクトが特定のクラスのインスタンスか、またはその子孫かを判定する

まとめ

is_subclass_of はPHPでクラスの継承関係を簡単に調べることができる便利な関数です。特に動的にクラスの関係性を確認したい場合に役立ちます。オブジェクトだけでなくクラス名の文字列も扱えるため、柔軟なコードを書きやすくなります。
関連の instanceofis_a() と併せて使うことで、オブジェクト指向プログラミングの理解とメンテナンス性が向上します。