Operadores de Tipo
instanceof
é usado para determinar se um variável do PHP
é uma objeto instânciado de uma certa
classe:
Example #1 Usando instanceof
com classes
<?php
class MyClass
{
}
class NotMyClass
{
}
$a = new MyClass;
var_dump($a instanceof MyClass);
var_dump($a instanceof NotMyClass);
?>
O exemplo acima produzirá:
bool(true) bool(false)
instanceof
pode também ser usado para determinar se uma variável
é um objeto instânciado de uma classe que herda de uma classe pai:
Example #2 Usando instanceof
com herança
<?php
class ParentClass
{
}
class MyClass extends ParentClass
{
}
$a = new MyClass;
var_dump($a instanceof MyClass);
var_dump($a instanceof ParentClass);
?>
O exemplo acima produzirá:
bool(true) bool(true)
Para verificar se um objeto não é uma instância de uma classe, o
operador lógico not
pode ser usado.
Example #3 Usando instanceof
para verificar se o objeto não é uma
instância da classe
<?php
class MyClass
{
}
$a = new MyClass;
var_dump(!($a instanceof stdClass));
?>
O exemplo acima produzirá:
bool(true)
Por fim, instanceof
pode também ser usado para determinar se
uma variável é um objeto instânciado de uma classe que implementa uma
interface:
Example #4 Usando instanceof
para classe
<?php
interface MyInterface
{
}
class MyClass implements MyInterface
{
}
$a = new MyClass;
var_dump($a instanceof MyClass);
var_dump($a instanceof MyInterface);
?>
O exemplo acima produzirá:
bool(true) bool(true)
Embora instanceof
é usualmente usado com um nome de classe literal,
ele pode também ser usado com outro objeto ou uma variável string:
Example #5 Usando instanceof
com outras variáveis
<?php
interface MyInterface
{
}
class MyClass implements MyInterface
{
}
$a = new MyClass;
$b = new MyClass;
$c = 'MyClass';
$d = 'NotMyClass';
var_dump($a instanceof $b); // $b é umn objeto da classe MyClass
var_dump($a instanceof $c); // $c é uma string 'MyClass'
var_dump($a instanceof $d); // $d é uma string 'NotMyClass'
?>
O exemplo acima produzirá:
bool(true) bool(true) bool(false)
instanceof não lança erros se a variável testada não for
um objeto, apenas retorna false
. Constantes não são permitidas
anteriormente ao PHP 7.3.0.
Example #6 Utilizando instanceof
para testar outras variáveis
<?php
$a = 1;
$b = NULL;
$c = imagecreate(5, 5);
var_dump($a instanceof stdClass); // $a é um inteiro
var_dump($b instanceof stdClass); // $b é NULL
var_dump($c instanceof stdClass); // $c é um resource
var_dump(FALSE instanceof stdClass);
?>
O exemplo acima produzirá:
bool(false) bool(false) bool(false) PHP Fatal error: instanceof expects an object instance, constant given
Desde oPHP 7.3.0, constantes são permitidas à esquerda do operador
instanceof
.
Example #7 Utilizando instanceof
em constantes
<?php
var_dump(FALSE instanceof stdClass);
?>
Saída do exemplo acima no PHP 7.3:
bool(false)
Desde o PHP 8.0.0, instanceof
pode ser utilizado em expressões arbitrárias.
A expressão precisa estar dentro parênteses e produzir uma string.
Example #8 Usando instanceof
em expressões arbitrárias
<?php
class ClassA extends \stdClass {}
class ClassB extends \stdClass {}
class ClassC extends ClassB {}
class ClassD extends ClassA {}
function getSomeClass(): string
{
return ClassA::class;
}
var_dump(new ClassA instanceof ('std' . 'Class'));
var_dump(new ClassB instanceof ('Class' . 'B'));
var_dump(new ClassC instanceof ('Class' . 'A'));
var_dump(new ClassD instanceof (getSomeClass()));
?>
Saída do exemplo acima no PHP 8:
bool(true) bool(true) bool(false) bool(true)
O operador instanceof
tem uma variação funcional
chamada is_a() function.