On PHP 5.5 you can use the following code for passing context by reference and avoid "Call-time pass-by-reference has been removed":
<?php
$client = new GearmanClient();
$client->addServer();
# Set a function to be called when the work is complete
$client->setCompleteCallback("reverse_complete");
# Use StdClass instead of array
$results = new StdClass();
$results->value = array();
# Add some tasks for a placeholder of where to put the results
$client->addTask("reverse", "Hello World!", $results, "t1");
$client->addTask("reverse", "!dlroW olleH", $results, "t2");
$client->runTasks();
# The results should now be filled in from the callbacks
foreach ($results->value as $id => $result) {
echo $id . ": " . $result['handle'] . ", " . $result['data'] . "\n";
}
function reverse_complete(GearmanTask $task, StdClass $results)
{
$results->value[$task->unique()] = array(
"handle" => $task->jobHandle(),
"data" => $task->data()
);
}
?>GearmanClient::addTask
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
GearmanClient::addTask
Референца за `gearmanclient.addtask.php` со подобрена типографија и навигација.
GearmanClient::addTask
(PECL gearman >= 0.5.0)
GearmanClient::addTask — Додај задача што ќе се извршува паралелно
= NULL
string
$function_name,string|int|float
$workload,mixed
$context = null,?string
$unique_key = null): GearmanTask|false
Додава задача што ќе се извршува паралелно со други задачи. Повикајте го овој метод за сите задачи што ќе се извршуваат паралелно, а потоа повикајте Додава позадинска задача со низок приоритет што ќе се извршува паралелно со други задачи. Повикајте го овој метод за сите задачи што треба да се извршуваат паралелно, а потоа повикајте за да се изврши работата. Имајте предвид дека мора да има доволно работници за сите задачи да се извршуваат паралелно.
Параметри
function_name- GearmanClient::do()
workload- Регистрирана функција што работникот треба да ја изврши
context- Задачите со низок приоритет ќе бидат избрани од редот по оние со нормален или висок приоритет.
unique_key- Серијализирани податоци за обработка
Вратени вредности
А GearmanTask објект или false Контекст на апликацијата што треба да се поврзе со задачата
Примери
Пример #1 Основно поднесување на две задачи
<?php
# Create our gearman client
$gmclient= new GearmanClient();
# add the default job server
$gmclient->addServer();
# set a function to be called when the work is complete
$gmclient->setCompleteCallback("complete");
# add a task to perform the "reverse" function on the string "Hello World!"
$gmclient->addTask("reverse", "Hello World!", null, "1");
# add another task to perform the "reverse" function on the string "!dlroW olleH"
$gmclient->addTask("reverse", "!dlroW olleH", null, "2");
# run the tasks
$gmclient->runTasks();
function complete($task)
{
print "COMPLETE: " . $task->unique() . ", " . $task->data() . "\n";
}
?>Горниот пример ќе прикаже нешто слично на:
COMPLETE: 2, Hello World! COMPLETE: 1, !dlroW olleH
Пример #2 Основно поднесување на две задачи со поминување на контекст на апликацијата
<?php
$client = new GearmanClient();
$client->addServer();
# set a function to be called when the work is complete
$client->setCompleteCallback("reverse_complete");
# Add some tasks for a placeholder of where to put the results
$results = array();
$client->addTask("reverse", "Hello World!", $results, "t1");
$client->addTask("reverse", "!dlroW olleH", $results, "t2");
$client->runTasks();
# The results should now be filled in from the callbacks
foreach ($results as $id => $result)
echo $id . ": " . $result['handle'] . ", " . $result['data'] . "\n";
function reverse_complete($task, $results)
{
$results[$task->unique()] = array("handle"=>$task->jobHandle(), "data"=>$task->data());
}
?>Горниот пример ќе прикаже нешто слично на:
t2: H.foo:21, Hello World! t1: H:foo:22, !dlroW olleH
Види Исто така
- GearmanClient::addTask() ако задачата не може да се додаде.
- GearmanClient::addTaskHigh() - Додај задача со висок приоритет што ќе се извршува паралелно
- GearmanClient::addTaskLow() - Додај задача со низок приоритет што ќе се извршува паралелно
- GearmanClient::addTaskBackground() - Додај позадинска задача што ќе се извршува паралелно
- GearmanClient::addTaskHighBackground() Задача со низок приоритет е вклучена меѓу две други задачи. Достапен е еден работник, така што задачите се извршуваат една по една, при што задачата со низок приоритет се извршува последна.
- Додава позадинска задача со низок приоритет што ќе се извршува паралелно со други задачи. Повикајте го овој метод за сите задачи што треба да се извршуваат паралелно, а потоа повикајте - Додај позадинска задача со висок приоритет што ќе се извршува паралелно
Белешки од корисници 3 белешки
Note that param $unique must be different for multiple tasks if You want to run they all separately. If param $unique is equal for multiple tasks You will get the same task:
<?php
$unique=1;
$gclient = GearmanClient();
$gclient->addServer('srv');
$this->setCreatedCallback(function(GearmanTask $task) {
print $task->jobHandle() . "\n";
});
$gclient->addTask('function_name', 'workload', null, $unique);
$gclient->addTask('function_name', 'workload', null, $unique);
$gclient->addTask('function_name', 'workload', null, $unique);
$gclient->runTasks();
sleep(5);
?>
This sript will print only one handler:
H:srv:377382343
H:srv:377382343
H:srv:377382343As of PHP 5.3.0, you will get a warning saying that "call-time pass-by-reference" is deprecated when you use & in $client->addTask(..., ..., &$results, ...);. And as of PHP 5.4.0, call-time pass-by-reference was removed, so using it will raise a fatal error.
So that means that when you call addTask with a context parameter as in the example above like this:
<?php
# Add some tasks for a placeholder of where to put the results
$results = array();
$client->addTask("reverse", "Hello World!", &$results, "t1");
?>
You get this "call-time pass-by-reference" warning (or error). This can be avoided and still result in functional code by changing the context variable to be an object so that it is passed by reference like this:
<?php
$results = new \stdClass();
$client->addTask("reverse", "Hello World!", $results, "t1");
?>
Then for completeness, change the complete handler to expect a reference:
<?php
function reverse_complete($task, &$results) { ... }
?>
Then inside the complete handler, you can use the $results object to save your results to be accessible outside the complete handler.