PHP 5 предоставляет возможность использовать контроль типов. На данный момент функции имеют возможность заставлять параметры быть либо объектами (путем указания имени класса в прототипе функции), либо массивами (начиная с PHP 5.1). Однако, если NULL использовался как значение параметра по умолчанию, то это будет также допустимо в качестве аргумента для последующего вызова.
Пример #1 Пример контроля типов
<?php
// Тестовый класс
class MyClass
{
/**
* Тестовая функция
*
* Первый параметр должен быть объектом типа OtherClass
*/
public function test(OtherClass $otherclass) {
echo $otherclass->var;
}
/**
* Другая тестовая функция
*
* Первый параметр должен быть массивом
*/
public function test_array(array $input_array) {
print_r($input_array);
}
}
// Другой тестовый класс
class OtherClass {
public $var = 'Hello World';
}
?>
В случае передачи аргумента неправильного типа результатом будет фатальная ошибка.
<?php
// Экземпляры каждого класса
$myclass = new MyClass;
$otherclass = new OtherClass;
// Ошибка: Аргумент 1 должен быть экземпляром класса OtherClass
$myclass->test('hello');
// Ошибка: Аргумент 1 должен быть экземпляром класса OtherClass
$foo = new stdClass;
$myclass->test($foo);
// Ошибка: Аргумент 1 не должен быть null
$myclass->test(null);
// Работает: Выводит Hello World
$myclass->test($otherclass);
// Ошибка: Аргумент 1 должен быть массив
$myclass->test_array('a string');
// Работает: Выводит массив
$myclass->test_array(array('a', 'b', 'c'));
?>
Также, контроль типов работает и с функциями:
<?php
// Пример класса
class MyClass {
public $var = 'Hello World';
}
/**
* Тестовая функция
*
* Первый параметр должен быть объект класса MyClass
*/
function MyFunction (MyClass $foo) {
echo $foo->var;
}
// Работает
$myclass = new MyClass;
MyFunction($myclass);
?>
Контроль типов допускает значения NULL:
<?php
/* Прием значения NULL */
function test(stdClass $obj = NULL) {
}
test(NULL);
test(new stdClass);
?>
Контроль типа может быть использован только с типами object и array (начиная с PHP 5.1). Традиционный контроль типа для int и string не поддерживается.