タイプヒンティング

PHP 5では、タイプヒンティング(Type Hinting)が導入されました。 これにより、関数は、 クラスの名前を関数プロトタイプの中に指定することにより、パラメータを オブジェクトが必ず指定されるようにすることができるようになりました。

例 19-39. タイプヒンティングの例

<?php
// An example class
class MyClass
{
    
/**
     * A test function
     *
     * First parameter must be an object of type OtherClass
     */
    
public function test(OtherClass $otherclass) {
        echo
$otherclass->var;
    }
}

// Another example class
class OtherClass {
    
public $var = 'Hello World';
}
?>

タイプヒントの指定を満たさないと致命的なエラーとなります。

<?php
// An instance of each class
$myclass = new MyClass;
$otherclass = new OtherClass;

// Fatal Error: Argument 1 must be an object of class OtherClass
$myclass->test('hello');

// Fatal Error: Argument 1 must be an instance of OtherClass
$foo = new stdClass;
$myclass->test($foo);

// Fatal Error: Argument 1 must not be null
$myclass->test(null);

// Works: Prints Hello World
$myclass->test($otherclass);
?>

タイプヒンティングは、関数でも使用できます。

<?php
// An example class
class MyClass {
    
public $var = 'Hello World';
}

/**
* A test function
*
* First parameter must be an object of type MyClass
*/
function MyFunction (MyClass $foo) {
    echo
$foo->var;
}

// Works
$myclass = new MyClass;
MyFunction($myclass);
?>

タイプヒントは、object型でのみ使用できます。 int および stringのような 通常の型でのタイプヒンティングはサポートされません。