每个PHP程序员都应该知道的进程知识
发布时间:2022-09-30 12:58:20 所属栏目:PHP教程 来源:
导读: 作为一个工作多年的老程序员,你是否对进程、线程依然理解的不够透彻?你是否在工作中使用到进程管理?你是否知道进程间通信方式有几种?
本文将讲述如下几个问题:
01进程和线程介绍
先
本文将讲述如下几个问题:
01进程和线程介绍
先
|
作为一个工作多年的老程序员,你是否对进程、线程依然理解的不够透彻?你是否在工作中使用到进程管理?你是否知道进程间通信方式有几种? 本文将讲述如下几个问题: 01进程和线程介绍 先说说进程和线程,进程是操作系统资源分配的最小单元,是程序执行的一个实例。在程序运行时系统就会创建一个进程,并为它分配资源,然后把该进程放入进程的就绪队列,这样进程调度器选中它的时候就会为它分配CPU时间片。 进程的状态有:新建态、就绪态、运行态、阻塞态、退出态,状态之间可以进行转换:就绪->运行,运行->就绪,运行->阻塞,阻塞->就绪 说完进程再说说线程,线程是CPU调度的最小单位,同时线程也是一个有限的系统资源。一个进程可以由多个线程组成,线程之间共享进程的所有资源,每个线程有自己的堆栈和局部变量。线程由CPU独立调度执行,在多CPU环境下就允许多个线程同时运行。同样,多线程也可以实现并发操作,每个请求分配一个线程来处理。 线程的状态和进程类似,一个进程可以运行多个线程,多个线程可以共享数据。只不过线程之前切换消耗的CPU资源比进程切换要小。 与进程不同的是同类的多个线程共享进程的堆和方法区资源,但每个线程有自己的程序计数器、虚拟机栈和本地方法栈,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。 进程和线程之间有什么区别呢? 02进程间通信方式 介绍进程之间通信之前先介绍一个概念:用户态和内核态。 当一个进程在执行自己的代码时处于用户态,当这个进程因为系统调用陷入内核代码中执行时处于内核态。执行的内核代码会使用当前进程的内核栈,每个进程都有自己的内核栈。 当用户运行一个程序时,该程序创建的进程开始时运行自己的代码,处于用户态。如果要执行文件操作、网络数据发送等操作必须通过write、send等系统调用,这些系统调用会调用内核的代码。进程会进入内核地址空间去执行内核代码来完成相应的操作,内核态的进程执行完后又会回到用户态。这样,用户态的程序就不能随意操作内核地址空间,具有一定的安全保护作用,保证进程间的地址空间不会互相冲突,一个进程的操作不会修改另一个进程地址空间中的数据。 进程从用户态切换到内核态常见的有三种方式:系统调用(如fork调用)、异常(如缺页异常)、外围设备中断。 下面说说进程间通信,即IPC,全称是InterProcess Communication。不同进程之间可以相互通信、交换数据。进程之间通信方式有:管道(包括无名管道和命名管道)、消息队列、信号量、共享内存、Socket、Streams。 03Swoole中进程管理介绍 下面我们用Swoole中的Process模块来加深一下对进程的理解。在Swoole中通过swoole_process 类来创建子进程,构造函数原型如下: 具体参数含义可以参考Swoole官方文档,下面我们将在一个进程中创建子进程,并进行进程间通信。 在命令行执行 php process.php,运行后的结果如下: 这就是进程之间通过管道通信的例子php程序员,创建子进程,并设定回调函数。Event::add 将管道文件描述符 $process->pipe 加入到事件循环中。第一行输出的hello world 是回调函数输出的,而 read:aaaaaa 是事件循环执行时从管道里读出的数据。 关于Swoole中进程间通信还有其他方式,在此不一一列举。以上内容,如有错误,欢迎指正! (编辑:PHP编程网 - 钦州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐


浙公网安备 33038102330484号