Threaded::synchronized

(PECL pthreads >= 2.0.0)

Threaded::synchronizedSincronización

Descripción

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

Se ejecuta el bloque mientras se retienen los candados de sincronización de los objetos referenciados para el contexto llamante.

Parámetros

block

El bloque de código a ejecutar

args

Lista variable de argumentos a utilizar como argumento de la función

Valores devueltos

El valor devuelto del bloque

Ejemplos

Ejemplo #1 Sincronización

<?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());
?>

El resultado del ejemplo sería:

bool(true)

add a note

User Contributed Notes 1 note

up
4
john dot wellesz at teaser dot fr
11 years ago
Threaded::synchronized() allows you to safely set or read synchronization conditions and act upon them (using ::wait() and ::notify()) knowing that only one call to synchronized() on the referenced object can be executed at a particular time, other calls from different thread contexts will block until the path is cleared by a call to ::wait() inside your ::Synchronized() closure.
To Top