并发和并行是现代编程中的基本概念,允许应用程序通过交错执行(并发)或同时执行(并行)同时执行多个任务。 PHP 主要以其同步执行模型而闻名,现已发展为通过各种技术支持这些范例。
PHP 的标准执行模型
PHP 传统上遵循同步执行模型,尤其是在典型的 Web 服务器设置中与 Apache 一起使用时。在此模型中,每个 HTTP 请求都由单个 PHP 进程处理。处理请求涉及的步骤包括:
- Apache 接收 HTTP 请求 并将其转发给 PHP。
- PHP 在单个线程中从头到尾执行脚本。
- PHP 将输出 返回给 Apache,然后 Apache 将响应发送回客户端。
此模型确保简单性和易于理解,但对于需要并行执行或同时处理多个任务的任务来说可能会变得低效。
PHP 中并发性和并行性的演变
随着 Web 应用程序变得越来越复杂,PHP 中并发和并行执行的需求也在增长。让我们探索 PHP 提供的实现这些范例的技术。
1. 同步代码
同步代码是最简单的执行形式,其中任务一个接一个地执行。
echo “同步代码示例:n”;
函数 synchronousFunction() {
为 ($i = 0; $i
在此示例中,循环的每次迭代都按顺序执行,迭代之间有一秒的延迟。这种方法很简单,但对于可以从并行执行中受益的 I/O 密集型或 CPU 密集型任务来说效率较低。
2. 分叉进程
分叉创建一个与原始进程(父进程)同时运行的新进程(子进程)。这对于并行任务很有用。
echo “nForking 进程示例:n”;
函数 forkProcess() {
$pid = pcntl_fork();
如果($pid==-1){
die(‘无法分叉’);
} 否则如果 ($pid) {
echo “父进程: PID $pidn”;
pcntl_wait($状态); // 防止僵尸儿童
} 别的 {
echo “子进程:来自子进程的你好!n”;
退出(0);
}
}
forkProcess();
在这段代码中,pcntl_fork() 创建了一个子进程。父进程和子进程同时执行,允许并行任务执行。父进程等待子进程完成以避免创建僵尸进程。
3. 线程
PHP 的线程功能可以通过 pthreads 等扩展来使用。线程比进程更轻,并且共享相同的内存空间,因此适合需要共享数据的任务。
if (!class_exists(‘线程’)) {
die(“此 PHP 版本不支持线程”);
}
echo “nThreading 示例:n”;
类 MyThread 扩展 Thread {
公共函数运行(){
为 ($i = 0; $i start();
$线程->join();
这个例子定义了一个扩展Thread的MyThread类。 run方法在一个新线程中执行,与主线程并发运行。这种方法对于 I/O 密集型操作很有用,其中线程可以处理等待资源。
4. 发电机
生成器提供了一种实现简单协同例程的方法,允许函数迭代地产生结果,而不会阻塞整个程序。
echo “nGenerators 示例:n”;
函数简单生成器(){
产生“第一”;
产量“第二”;
产生“第三”;
}
$gen = simpleGenerator();
foreach ($gen as $value) {
echo “生成器产量: $valuen”;
}
生成器使用yield关键字一次生成一个值,允许暂停和恢复函数,促进一种协作式多任务处理。
PHP 从同步根源到支持各种形式的并发和并行性已经取得了很大的进步。虽然同步代码对于许多用例来说仍然简单有效,但分叉进程、线程和使用生成器等技术为有效处理复杂、可并行的任务开辟了新的可能性。
以上就是PHP 中的并发和并行的详细内容,更多请关注php中文网其它相关文章!