(PECL pthreads >= 2.0.0)

Описание

public mixed Threaded::synchronized ( Closure $block [, mixed $... ] )

Выполняет блок при сохранении блокировки синхронизации объектов, на которые имеются ссылки, для вызывающего контекста

Список параметров

block

Блок кода для выполнения

...

Список аргументов переменной длины для использования в качестве аргументов функции блока

Возвращаемые значения

Возвращаемое значение из блока

Примеры

Пример #1 Синхронизация

<?php
class My extends Thread {
    public function run() {
        $this->synchronized(function($thread){
            if (!$thread->done)
                $thread->wait();
        }, $this);
    }
}
$my = new My();
$my->start();
$my->synchronized(function($thread){
    $thread->done = true;
    $thread->notify();
}, $my);
var_dump($my->join());
?>

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

bool(true)

Threaded :: synchronized () позволяет вам безопасно устанавливать или считывать условия синхронизации и действовать в соответствии с ними (используя :: wait () и :: notify ()), зная, что в объекте, на который имеется ссылка, может быть выполнен только один вызов В конкретное время другие вызовы из разных контекстов потока будут блокироваться до тех пор, пока путь не будет очищен вызовом :: wait () внутри замыкания :: Synchronized ().