PHP 多线程与 Node.js 事件循环对比
背景
PHP 和 Node.js 都是流行的 Web 开发语言,但它们采用不同的并发模型。 PHP 使用多线程,而 Node.js 使用事件循环。
多线程
在多线程模型中,应用程序可以创建多个线程,每个线程同时执行不同的任务。每个线程都有自己的独立内存空间和执行堆栈。
事件循环
事件循环是一种单线程模型,其中一个单一的线程处理所有传入请求和事件。当发生事件时,如 HTTP 请求或文件系统操作,事件将被放入队列中。事件循环会轮询此队列并依次处理这些事件。
对比
优点:
- 多线程:对于计算密集型任务,可以提高效率,因为可以使用多个 CPU 内核并行执行任务。
- Node.js 事件循环:对于 I/O密集型任务,可以提高效率,因为不需要为每个请求创建线程。
缺点:
- 多线程:线程管理需要同步和锁机制,可能会导致复杂性和性能问题。
- Node.js 事件循环:无法充分利用多核 CPU,因为所有任务都是在同一线程上执行的。
实战案例
多线程 (PHP):
<?php use Threaded; // 创建一个线程队列 $threads = new Threaded(); // 创建线程并添加到队列 for ($i = 0; $i < 4; $i++) { $threads[] = new Thread(function () { // 模拟长时间运行的任务 sleep(rand(0, 10)); echo "Thread {$_GET['thread']} finished.\n"; }); } // 启动所有线程 foreach ($threads as $thread) { $thread->start(); } // 等待所有线程完成 foreach ($threads as $thread) { $thread->join(); } // 输出结果 foreach ($threads as $thread) { echo $thread->getResult() . "\n"; }
事件循环 (Node.js):
const http = require('http'); // 创建 HTTP 服务器 const server = http.createServer((req, res) => { // 模拟长时间运行的任务 setTimeout(() => { res.end('Thread ' + req.url + ' finished.'); }, rand(0, 10) * 1000); }); // 启动服务器 server.listen(3000, () => { console.log('Server listening on port 3000'); });