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
is_a
(PHP 4 >= 4.2.0, PHP 5)
is_a — Проверяет, принадлежит ли объект к данному классу или содержит данный класс в числе своих предков
Описание
$object
, string $class_name
[, bool $allow_string = FALSE
] )
Проверяет, принадлежит ли объект object
к данному классу или содержит данный класс в числе своих предков
Список параметров
-
object -
Проверяемый объект
-
class_name -
Имя класса
-
allow_string -
Если параметр установлен в
FALSE, то не допускается имя класса в виде строки в качестве параметраobject. Это также предотвращает вызов автозагрузчика, если класс не существует.
Возвращаемые значения
Возвращает TRUE, если объект принадлежит данному классу или
имеет данный класс в числе своих предков, иначе возвращается FALSE.
Список изменений
| Версия | Описание |
|---|---|
| 5.3.9 |
Добавлен параметр allow_string
|
| 5.3.0 |
Данная функция больше не считается устаревшей, а значит,
не будет выводить предупреждения E_STRICT.
|
| 5.0.0 |
Эта функция была помечена устаревшей в пользу оператора
instanceof.
Вызов данной функции вызовет предупреждение уровня
E_STRICT.
|
Примеры
Пример #1 Пример использования is_a()
<?php
// объявление класса
class WidgetFactory
{
var $oink = 'moo';
}
// создание нового объекта
$WF = new WidgetFactory();
if (is_a($WF, 'WidgetFactory')) {
echo "да, \$WF все еще WidgetFactory\n";
}
?>
Пример #2 Использование оператора instanceof в PHP 5
<?php
if ($WF instanceof WidgetFactory) {
echo 'Да, $WF - WidgetFactory';
}
?>
Смотрите также
- get_class() - Возвращает имя класса, к которому принадлежит объект
- get_parent_class() - Возвращает имя родительского класса для объекта или класса
- is_subclass_of() - Проверяет, содержит ли объект в своем дереве предков указанный класс
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.
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.
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...
Workaround for older PHP-Versions:
function is_a($anObject, $aClass) {
return get_class($anObject) == strtolower($aClass)
or is_subclass_of($anObject, $aClass);
}
Why I test if class `A` inherit class `B` or implements interface `C` before I create class `A`?
<?
//That isn't work:
//1. function is_A()
if(is_A('A','B'))$a=new A;
if(is_A('A','C'))$a=new A;
//2. operator instanceOf
if(A instanceOf B)$a=new A;
if(A instanceOf C)$a=new A;
?>
Lazy Instantiation using is_a() and php5
<?php
class ObjectA
{
public function print_line($text)
{
print $text . "\n";
}
}
class ObjectB
{
public function ObjectA()
{
static $objecta;
if (!is_a($objecta, 'ObjectA'))
{
$objecta = new ObjectA;
}
return $objecta;
}
}
$obj = new ObjectB;
$obj->ObjectA()->print_line('testing, 1 2 3');
?>
In the above example, ObjectA is not instantiated until needed by ObjectB. Then ObjectB can continually use it's creation as needed without reinstantiating it.
There are other ways, but I like this one :-)
