并发和并行是现代编程中的基本概念,允许应用程序通过交错执行(并发)或同时执行(并行)同时执行多个任务。 PHP 主要以其同步执行模型而闻名,现已发展为通过各种技术支持这些范例。
PHP 传统上遵循同步执行模型,尤其是在典型的 Web 服务器设置中与 Apache 一起使用时。在此模型中,每个 HTTP 请求都由单个 PHP 进程处理。处理请求涉及的步骤包括:
此模型确保简单性和易于理解,但对于需要并行执行或同时处理多个任务的任务来说可能会变得低效。
随着 Web 应用程序变得越来越复杂,PHP 中并发和并行执行的需求也在增长。让我们探索 PHP 提供的实现这些范例的技术。
同步代码是最简单的执行形式,其中任务一个接一个地执行。
echo "Synchronous Code Example:\n"; function synchronousFunction() { for ($i = 0; $i < 3; $i++) { echo "Synchronous Loop Iteration: $i\n"; sleep(1); } } synchronousFunction();
在此示例中,循环的每次迭代都按顺序执行,迭代之间有一秒的延迟。这种方法很简单,但对于可以从并行执行中受益的 I/O 密集型或 CPU 密集型任务来说效率较低。
分叉创建一个与原始进程(父进程)同时运行的新进程(子进程)。这对于并行化任务很有用。
echo "\nForking Process Example:\n"; function forkProcess() { $pid = pcntl_fork(); if ($pid == -1) { die('could not fork'); } else if ($pid) { echo "Parent Process: PID $pid\n"; pcntl_wait($status); // Protect against Zombie children } else { echo "Child Process: Hello from the child process!\n"; exit(0); } } forkProcess();
在此代码中,pcntl_fork() 创建一个子进程。父进程和子进程同时执行,允许并行任务执行。父进程等待子进程完成以避免创建僵尸进程。
PHP 的线程功能可通过 pthreads 等扩展来使用。线程比进程轻,并且共享相同的内存空间,因此适合需要共享数据的任务。
if (!class_exists('Thread')) { die("Threads are not supported in this PHP build\n"); } echo "\nThreading Example:\n"; class MyThread extends Thread { public function run() { for ($i = 0; $i < 3; $i++) { echo "Thread Loop Iteration: $i\n"; sleep(1); } } } $thread = new MyThread(); $thread->start(); $thread->join();
此示例定义了一个扩展 Thread 的 MyThread 类。 run方法在一个新线程中执行,与主线程并发运行。这种方法对于 I/O 密集型操作非常有用,其中线程可以处理等待资源。
生成器提供了一种实现简单协同例程的方法,允许函数迭代地产生结果,而不会阻塞整个程序。
echo "\nGenerators Example:\n"; function simpleGenerator() { yield 'First'; yield 'Second'; yield 'Third'; } $gen = simpleGenerator(); foreach ($gen as $value) { echo "Generator Yielded: $value\n"; }
生成器使用yield关键字一次生成一个值,允许暂停和恢复函数,从而促进一种协作式多任务处理。
PHP 从同步根源到支持各种形式的并发和并行性已经取得了很大的进步。虽然同步代码对于许多用例来说仍然简单有效,但分叉进程、线程和使用生成器等技术为有效处理复杂、可并行的任务开辟了新的可能性。
以上是PHP 中的并发和并行的详细内容。更多信息请关注PHP中文网其他相关文章!