En PHP, la programmation asynchrone permet d'effectuer des tâches chronophages sans bloquer le flux d'exécution. Les techniques d'implémentation de la programmation asynchrone incluent : Fonctions de rappel : pointeurs de fonction qui exécutent le code une fois l'exécution d'une autre fonction terminée. Coroutines : mécanisme multitâche léger qui permet de basculer entre plusieurs exécutions de fonctions dans le même thread. Parallélisation : utilisation de différents threads ou processus pour effectuer plusieurs tâches simultanément. Exemple pratique : En traitant les requêtes HTTP en parallèle, vous pouvez réduire considérablement le temps de traitement tout en conservant la réactivité.
Une brève discussion sur la programmation asynchrone des fonctions PHP
Introduction
En PHP, le mode de programmation asynchrone nous permet d'effectuer des tâches chronophages sans bloquer le flux d'exécution en cours. Cet article explorera comment utiliser les fonctions de rappel, les coroutines et les techniques de parallélisation pour implémenter la programmation asynchrone en PHP, et illustrera comment appliquer ces techniques à travers un cas pratique.
Fonction de rappel
Une fonction de rappel est un pointeur de fonction qui permet d'exécuter du code une fois l'exécution d'une autre fonction terminée. Ils sont très utiles lors de la gestion d’opérations asynchrones. L'exemple suivant montre une opération asynchrone simple utilisant une fonction de rappel :
function long_task($seconds, callable $callback) { // 模拟耗时任务 sleep($seconds); // 执行回调函数 $callback(); } long_task(5, function () { echo "任务已完成!\n"; });
Coroutines
Les coroutines sont un mécanisme multitâche léger qui nous permet de basculer l'exécution de plusieurs fonctions dans le même thread. En utilisant des coroutines, nous pouvons gérer plusieurs tâches chronophages simultanément sans bloquer le flux d'exécution actuel.
Voici un exemple de programmation asynchrone utilisant la bibliothèque coroutine en PHP 7.2 :
$coroutine = function () { $data = yield long_task(5); echo "Data received: $data\n"; }; go($coroutine);
Parallélisation
Semblable à la programmation asynchrone, la parallélisation nous permet d'effectuer plusieurs tâches en même temps. Cependant, la parallélisation est effectuée dans différents threads ou processus, et non dans le même thread. La parallélisation peut être réalisée à l'aide des classes Process et Thread de PHP.
L'exemple suivant montre l'utilisation de la classe Process pour traiter deux tâches chronophages en parallèle :
$process1 = new Process(function () { long_task(5, function () { echo "任务 1 完成!\n"; }); }); $process2 = new Process(function () { long_task(3, function () { echo "任务 2 完成!\n"; }); }); $process1->start(); $process2->start(); $process1->wait(); $process2->wait();
Cas pratique : requête HTTP asynchrone
Comme cas pratique, on peut utiliser la technologie ci-dessus sans bloquer le courant flux d'exécution Traitez plusieurs requêtes HTTP en parallèle.
use GuzzleHttp\Client; use GuzzleHttp\Psr7\Request; use GuzzleHttp\Pool; use GuzzleHttp\Promise\EachPromise; // 创建 Guzzle 客户端 $client = new Client(); // 初始化请求队列 $queue = []; $urls = ['https://example.com', 'https://example2.com', 'https://example3.com']; foreach ($urls as $url) { $queue[] = new Request('GET', $url); } // 创建请求池并指定并发限制 $pool = new Pool($client, $queue, [ 'concurrency' => 5, 'fulfilled' => function (Response $response) { echo $response->getBody() . "\n"; } ]); // 开始并行处理请求 $pool->promise()->wait();
En traitant les requêtes HTTP en parallèle, nous pouvons réduire considérablement le temps de traitement tout en conservant la réactivité car le flux d'exécution actuel n'est pas bloqué.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!