Псевдо-типы и переменные, используемые в этой документации

mixed

mixed говорит о том, что параметр может принимать много (но необязательно все) типов.

gettype() например, принимает все типы PHP, тогда как str_replace() принимает только string и array.

number

number говорит о том, что параметр может быть либо integer, либо float.

callback

Некоторые функции, такие как call_user_func() или usort() принимают в качестве параметра определенные пользователем callback-функции. Callback-функции могут быть не только простыми функциями, но также и методами объектов, включая статические методы классов.

PHP-функция передается просто как строка ее имени. Можно использовать любую встроенную или пользовательскую функцию, кроме языковых конструкций, таких как: array(), echo(), empty(), eval(), exit(), isset(), list(), print() и unset().

Метод созданного объекта передается как массив, содержащий сам объект в элементе с индексом 0 и имя метода в элементе с индексом 1.

Статические методы классов также могут быть переданы без создания экземпляра объекта данного класса путем передачи имени класса вместо имени объекта в элементе с индексом 0.

Кроме общих пользовательских функций, create_function() также может быть использована для создания анонимной callback-функции. Начиная с версии PHP 5.3.0 стала возможным также передача замыканий в callback-параметр.

Пример #1 Примеры callback-функций

<?php 

// пример callback-функции
function my_callback_function() {
    echo 
'hello world!';
}

// пример callback-метода
class MyClass {
    static function 
myCallbackMethod() {
        echo 
'Hello World!';
    }
}

// Вариант 1: простой вызов callback
call_user_func('my_callback_function'); 

// Вариант 2: вызов статического метода класса
call_user_func(array('MyClass''myCallbackMethod')); 

// Вариант 3: вызов метода объекта
$obj = new MyClass();
call_user_func(array($obj'myCallbackMethod'));

// Вариант 4: вызов статического метода класса (с версии PHP 5.2.3)
call_user_func('MyClass::myCallbackMethod');

// Вариант 5: вызов относительного статического метода класса (с версии PHP 5.3.0)
class {
    public static function 
who() {
        echo 
"A\n";
    }
}

class 
extends {
    public static function 
who() {
        echo 
"B\n";
    }
}

call_user_func(array('B''parent::who')); // A
?>

Пример #2 Пример callback-вызова с использованием замыканий

<?php
// наше замыкание
$double = function($a) {
    return 
$a 2;
};

// это наш диапазон чисел
$numbers range(15);

// Используем здесь замыкание в качестве callback-функции
// для удвоения размера каждого элемента в диапазоне
$new_numbers array_map($double$numbers);

print 
implode(' '$new_numbers);
?>

Результат выполнения данного примера:

2 4 6 8 10

Замечание: В PHP 4 было необходимо использовать ссылку при создании callback-функции для того, чтобы она указывала на реальный объект, а не на его копию. За подробностями обращайтесь к разделу Объяснение ссылок.

Замечание:

Callback-функции, зарегистрированные такими функциями как call_user_func() и call_user_func_array(), не будут вызваны при наличии не пойманного исключения, брошенного в предыдущей callback-функции.

void

void в качестве типа результата означает, что возвращенное значение бесполезно. void в списке параметров означает, что функция не принимает параметров.

...

$... в прототипах функции означает and so on (и так далее). Это имя переменной используется когда функция может принимать бесконечное количество параметров.

Коментарии

Автор:
To recap mr dot lilov at gmail dot com's comment: If you want to pass a function as an argument to another function, for example "array_map", do this:

regular functions: 
<? 
array_map
(intval$array)
?>

static functions in a class:
<?
array_map
(array('MyClass''MyFunction'), $array)
?>

functions from an object:
<?
array_map
(array($this'MyFunction'), $array)
?>

I hope this clarifies things a little bit
2007-02-01 04:15:29
http://php5.kiev.ua/manual/ru/language.pseudo-types.html
Parent methods for callbacks should be called 'parent::method', so if you wish to call a non-static parent method via a callback, you should use a callback of
<?
 
// always works
 
$callback = array($this'parent::method'

 
// works but gives an error in PHP5 with E_STRICT if the parent method is not static
 
$callback array('parent''method'); 
?>
2007-02-08 16:44:42
http://php5.kiev.ua/manual/ru/language.pseudo-types.html
Автор:
The mixed pseudotype is explained as meaning "multiple but not necessarily all" types, and the example of str_replace(mixed, mixed, mixed) is given where "mixed" means "string or array".
Keep in mind that this refers to the types of the function's arguments _after_ any type juggling.
2007-05-24 01:44:32
http://php5.kiev.ua/manual/ru/language.pseudo-types.html
An example with PHP 5.3 and lambda functions

<?php

  array_map 
(function ($value) {
    return new 
MyFormElement ($value);
  }, 
$_POST);

?>
2009-04-20 06:19:31
http://php5.kiev.ua/manual/ru/language.pseudo-types.html
I noticed two important thing about putting callbacks into an arg list when calling a function:

1. The function to which the callback refers must be defined earlier in the source stream. So for example:

function main() {...; usort($array, 'sortfunction'); ... }
function sortfunction($a, $b){ return 0; }

Will NOT work, but this will:

function sortfunction($a, $b){ return 0; }
function main() {...; usort($array, 'sortfunction'); ... }

2. It's not really just a string. For example, this doesn't work:

usort($array, ($reverse?'reversesorter':'forwardsorter'));

I found these two discoveries quite counterintuitive.
2009-06-11 20:44:44
http://php5.kiev.ua/manual/ru/language.pseudo-types.html
The documentation is a little confusing, and with the recent OO changes it adds a little more to the confusion.

I was curious whether you could pass an object through the user func, modify it in that callback and have the actual object updated or whether some cloning was going on behind the scenes.

<?php
   
class Test
   
{
        var 
$sValue 'abc';

        function 
testing($objTest)
        {
           
$objTest->sValue '123';
        }
    }

   
$obj = new Test();

   
call_user_func(array($obj'testing'), $obj);

   
var_dump($obj);

?>

This works as expected: The object is not cloned, and $sValue is properly set to '123'. With the OO changes in PHP 5, you don't need to do "function testing(&$objTest)" as it is already passed by reference.
2009-08-29 12:20:46
http://php5.kiev.ua/manual/ru/language.pseudo-types.html
Note that (e.g.) usort calls on static methods of classes in a namespace need to be laid out as follows:

usort($arr, array('\Namespace\ClassName', 'functionName'));
2010-12-06 06:44:43
http://php5.kiev.ua/manual/ru/language.pseudo-types.html

    Поддержать сайт на родительском проекте КГБ