- 目录
- 1.前言
- 2.进程与线程的概念
- 3.进程与线程的区别
- 4.实现PHP多线程
- 4.1 pcntl_fork函数
- 4.2 pcntl_fork的作用
- 4.3 pcntl_fork的返回值
- 4.4 代码实战
- 4.4.1 官方案例,详见pcntl_fork1.php
- 4.4.2 改进案例,详见pcntl_fork2.php
- 5. 扩展pthreads安装和使用
- 5.1 windows下安装
- 5.1.1安装注意事项
- 5.1.2下载pthreads扩展
- 5.1.3安装pthreads扩展
- 5.1.4测试pthreads扩展,详见AsyncOperation.php
- 5.2 Thread类和方法
- 5.2.1案例:对比使用线程和使用内置函数运算的时间差
- 5.2.2使用多进程代替多线程
- 5.2.3案例:多进程代替多线程
- 6. 总结
- 7. 参考资料
1.前言
PHP 5.3 以上版本支持PHP扩展pthreads,可以使PHP真正地支持多线程。多线程在处理重复性的循环任务,能够大大缩短程序执行时间,而且多线程是个重要的核心点,我们有必要去了解它。
代码分享:https://github.com/mtdgclub/Thread
2.进程与线程的概念
- 进程是并发执行的程序在执行过程中分配和管理资源的基本单位。
- 线程是进程内的一个执行单元,是比进程更小的能独立运行的基本单位。
3.进程与线程的区别
- 最小单位
进程是资源分配最小单位,线程是程序执行的最小单位。计算机在执行程序时,会为程序创建相应的进程,进行资源分配时,是以进程为单位进行相应的分配。每个进程都有相应的线程,在执行程序时,实际上是执行相应的一系列线程。
- 资源空间
进程有独立的地址空间,线程没有独立的地址空间。每启动一个进程,系统都会为其分配地址空间,建立数据表来维护代码段、堆栈段和数据段;而同一进程的线程则共享本进程的地址空间。
- 资源归属
进程之间的资源是独立的;同一进程内的线程共享本进程的资源。
- 执行过程
每个独立的进程有一个程序运行的入口和顺序执行序列。