is_a
(PHP 4 >= 4.2.0, PHP 5, PHP 7, PHP 8)
is_a — オブジェクトが指定された型のものか、部分型であるかを調べる
説明
指定した object_or_class
が class
オブジェクトの型であるか、
あるいは class
が、
その上位型のひとつであるかを調べます。
パラメータ
object_or_class
-
調べたいクラス名、またはオブジェクトのインスタンス
class
-
クラスまたはインターフェイスの名前。
allow_string
-
このパラメータを
false
にすると、 クラス名を表す文字列をobject_or_class
に指定できなくなります。 そして、クラスが存在しない場合のオートローダーの呼び出しもしなくなります。
例
例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() - あるオブジェクトが指定したクラスのサブクラスに属するか (あるいは指定したインターフェイスを実装しているか) どうかを調べる
+add a note
User Contributed Notes 7 notes
Ronald Locke ¶
8 years ago
Please note that you have to fully qualify the class name in the second parameter.
A use statement will not resolve namespace dependencies in that is_a() function.
<?php
namespace foo\bar;
class A {};
class B extends A {};
?>
<?php
namespace har\var;
use foo\bar\A;
$foo = new foo\bar\B();
is_a($foo, 'A'); // returns false;
is_a($foo, 'foo\bar\A'); // returns true;
?>
Just adding that note here because all examples are without namespaces.
Aron Budinszky ¶
13 years ago
Be careful! Starting in PHP 5.3.7 the behavior of is_a() has changed slightly: when calling is_a() with a first argument that is not an object, __autoload() is triggered!
In practice, this means that calling is_a('23', 'User'); will trigger __autoload() on "23". Previously, the above statement simply returned 'false'.
More info can be found here:
https://bugs.php.net/bug.php?id=55475
Whether this change is considered a bug and whether it will be reverted or kept in future versions is yet to be determined, but nevertheless it is how it is, for now...
p dot scheit at zweipol dot net ¶
17 years ago
At least in PHP 5.1.6 this works as well with Interfaces.
<?php
interface test {
public function A();
}
class TestImplementor implements test {
public function A () {
print "A";
}
}
$testImpl = new TestImplementor();
var_dump(is_a($testImpl,'test'));
?>
will return true
cesoid at yahoo dot com ¶
19 years ago
is_a returns TRUE for instances of children of the class.
For example:
class Animal
{}
class Dog extends Animal
{}
$test = new Dog();
In this example is_a($test, "Animal") would evaluate to TRUE as well as is_a($test, "Dog").
This seemed intuitive to me, but did not seem to be documented.
dkrupyanskiy[at]gmail ¶
6 years ago
Looks like the function signature given in description is wrong. Actually it can take a string as a first parameter in the case if $allow_string is set to true.
It took some time to find out how the last parameter should be used. Please consider the following example
<?php
class Foo{}
spl_autoload_register(
function($classname){
printf('autoload has been triggered for %s%s', $classname, PHP_EOL);
}
);
var_dump(is_a('UndefinedClassName', Foo::class, true));
?>
eitan at mosenkis dot net ¶
12 years ago
As of PHP 5.3.9, is_a() seems to return false when passed a string for the first argument. Instead, use is_subclass_of() and, if necessary for your purposes, also check if the two arguments are equal, since is_subclass_of('foo', 'foo') will return false, while is_a('foo', 'foo') used to return true.
↑ and ↓ to navigate •
Enter to select •
Esc to close
Press Enter without
selection to search using Google