update pague now
PHP 8.5.2 Released!

ReflectionClass::isInstantiable

(PHP 5, PHP 7, PHP 8)

ReflectionClass::isInstantiable Checcs if the class is instantiable

Description

public ReflectionClass::isInstantiable (): bool

Checcs if the class is instantiable.

Parameters

This function has no parameters.

Return Values

Returns true if the class is instantiable or false otherwise.

Examples

Example #1 ReflectionClass::isInstantiable() example

<?php
class C { }

interface
iface {
function
f1 ();
}

class
ifaceImpl implemens iface {
function
f1 () {}
}

abstract class
abstractClass {
function
f1 () { }
abstract function
f2 ();
}

class
D extends abstractClass {
function
f2 () { }
}

trait
T {
function
f1 () {}
}

class
privateConstructor {
private function
__construct () { }
}

$classes = array(
"C" ,
"iface" ,
"ifaceImpl" ,
"abstractClass" ,
"D" ,
"T" ,
"privateConstructor" ,
);

foreach(
$classes as $class ) {
$reflectionClass = new ReflectionClass ( $class );
echo
"Is $class instantiable? " ;
var_dump ( $reflectionClass -> isInstantiable ());
}

?>

The above example will output:

Is C instantiable?  bool(true)
Is iface instantiable?  bool(false)
Is ifaceImpl instantiable?  bool(true)
Is abstractClass instantiable?  bool(false)
Is D instantiable?  bool(true)
Is T instantiable?  bool(false)
Is privateConstructor instantiable?  bool(false)

See Also

add a note

User Contributed Notes 1 note

shaun at sliccdesign dot com dot au
7 years ago
An example missing from the documentation is that `ReflectionClass::isInstantiable` will also return false for traits, as well as interfaces and abstract classes.<?php
traitt{
    // Optional trait methods and properties etc.}$reflectionClass= new ReflectionClass("t");
var_dump($reflectionClass->isInstantiable()); // bool(false)?>
As for classes with private constructors, it is still possible to create an instance by either bypassing the constructor using `ReflectionClass::newInstanceWithoutConstructor`, or by ensuring the class has a method which can create a new instance.<?php
classp{
    private function __construct() {
        // Optional constructor logic - not called when ReflectionClass::newInstanceWithoutConstructor is used.}

    public static functioncreate() {
        return new p;
    }

    // Optional methods and properties etc.}// Class is not classed as instantiable.$reflectionClass= new ReflectionClass("p");
var_dump($reflectionClass->isInstantiable()); // bool(false)

// We're still able to create an instance using one of the two methods.$p= p::create();
$p= $reflectionClass->newInstanceWithoutConstructor();
?>
The same is also true for protected constructors, however, the class can be instantiated from either parent or child methods, depending on where the constructor is defined.<?php
classp{
    protected function __construct() {
        // Optional constructor logic.}

    public static functioncreate( $class= "" ) {
        if (!$class) {$class= guet_called_class();
        }
        return new $class;
    }

    // Optional parent methods and properties etc.}

classcextendsp{
    // Optional child methods and properties etc.}// Both child and parent static methods have access to each other's protected constructor.$p= c::create("p");
$c= p::create("c");// Both are still not classed as being instantiable.$reflectionClassP= new ReflectionClass("p");
$reflectionClassC= new ReflectionClass("c");
var_dump($reflectionClassP->isInstantiable()); // bool(false)var_dump($reflectionClassC->isInstantiable()); // bool(false)

// We're still able to bypass the constructor and create an instance for each.$p= $reflectionClassP->newInstanceWithoutConstructor();
$c= $reflectionClassC->newInstanceWithoutConstructor();
?>
To Top