## 进程与线程的区别
**根本区别:**
> 进程是资源分配最小单位,资源包括内存,硬盘等
> 线程是程序执行的最小单位
> 计算机在执行程序时,会为程序创建相应的进程,进行资源分配时,是以进程为单位进行相应的分配。
> 每个进程都有相应的线程,在执行程序时,实际上是执行相应的一系列线程。
![](https://img.kancloud.cn/af/ae/afaec1cbd16a322018386edb581b7479_500x344.jpg)
**资源拥有**
> 进程之间的资源是独立的;
> 同一进程内的线程共享本进程的资源
![](https://img.kancloud.cn/6c/ea/6ceafb18b1d3f80b7a73388df075f55c_500x399.jpg)
## CPU个数、核心数、线程数的关系
> 1. CPU个数:是指物理上,即硬件上的核心数
> 2. 核心数:是逻辑上的,简单理解为逻辑上模拟出的核心数
> 3. 线程数:是同一时刻设备能并行执行的程序个数
> 线程数 = cpu个数 * 核数
## 并发和并行的概念
> 并行:指两个或多个线程在**同一时刻点**发生,CPU**同时执行**
> 并发:指两个或多个线程在**同一时间段内**发生,**CPU交替执行**
## 时间片轮转机制(Round-Robin,RR)
> 根据先进先出原则,排成队列(就绪队列)。
> 调度时,将CPU分配给队首进程,让其执行一个时间段(称为:时间片),时间片通常为10-100ms数量级,
> 当执行的时间片用完时,会由计时器发出时钟中断请求,调度程序便据此来停止该进程的执行,
> 并将它排到队列末尾,
> 然后再把CPU重新分配给当前队列的队首进程,
> 同理如此往复。
##### 时间片大小取决于:
1. 系统对响应时间的要求
2. 就绪队列中进程的数目
3. 系统的处理能力
## 时间片轮转机制实现思想
系统将所有的就绪进程按**先来先服务**算法的原则,排成一个队列,每次调度时,系统把处理机分配给队列首进程,并让其执行一个时间片。
当执行的时间片用完时,由一个计时器发出时钟中断请求,调度程序根据这个请求停止该进程的运行,将它送到就绪队列的末尾,再把处理机分给就绪队列中新的队列首进程,同时让它也执行一个时间片
## 抢占式线程调度
一个线程在执行自己的任务时,虽然任务还没有执行完,但是CPU会迫使它暂停,让其它线程占有CPU的使用权
## 协作式线程调度
一个线程在执行自己的任务时,不允许被中途打断,一定等当前线程将任务执行完毕后才会释放对cpu的占有,其它线程才可以抢占该cpu
## 抢占式线程调度与协作式线程调度对比:
> 抢占式线程调度:
> 不易发生饥饿现象,不易因为一个线程的问题而影响整个进程的执行,但是其频繁阻塞与调度,会造成系统资源的浪费。
> 协作式的线程调度:
> 很容易因为一个线程的问题导致整个进程中其它线程饥饿
- php7性能优化
- php代码性能常见优化技巧
- PHP对象在内存中的分配
- PHP7垃圾回收机制详解
- 细说php5和php7垃圾回收区别
- php核心技术与实战
- 传值与传引用的区别
- php7语法糖好甜,让你迷上魔术方法
- php7魔术方法__call的最佳实战
- 精通PHP正则表达式,看这一篇就够啦!
- 不懂对象设计原则,都不好意思自称php大师
- socket通信很难?这一文让你轻松搞懂
- 详解CGI,FastCGI,php-fpm三者区别与联系
- php7.2编译安装与环境搭建
- php-fpm的配置和优化
- linux php扩展安装示例-redis扩展安装
- phpstorm配置Xdebug最完整教程,绝对成功
- PHP利用Mysql锁解决高并发问题
- 设计模式
- 注册模式
- 创建型模式
- 简单工厂模式
- 工厂方法模式
- 抽象工厂模式
- 三种工厂模式比较
- 建造者模式
- 单例模式
- 结构性模式
- 外观模式
- 适配器模式
- 代理模式
- 组合模式
- 享元模式
- 装饰模式
- 桥模式
- 行为型模式
- 中介者模式
- 观察者模式
- 命令模式
- 迭代器模式
- 模板方法模式
- 策略模式
- 状态模式
- 备忘录模式
- 解释器模式
- 职责链模式
- 访问者模式
- Thinkphp5.1钩子与行为
- composer
- 当本地安装的composer是2.x,而项目需要composer1.x
- php中的数种依赖注入
- 访问控制权限
- Casbin基础知识
- thinkphp5+webuploader实现大文件分片上传
- 多线程
- 基于PCNTl扩展的PHP多进程管理库
- 后端开发必备
- 理解TCP/IP与UDP协议、Socket的正确姿势
- 进程线程,CPU核心数,时间片轮转机制解读
- IO多路复用的三种机制:select 、poll 、epoll
- gitlab搭建企业级私有的版本控制环境以及使用,亲测有效
- 深入浅出,轻松搞懂HTTPS工作原理
- 计算机基础
- 状态机
- 逆波兰表达式
- 网络与协议
- 网站安全
- CSRF跨站点伪造请求攻击
- ssh连接服务器报错:server responded “Algorithm negotiation failes” 解决办法
- 何使用Nativefier将web页面打包为桌面应用
- Nginx进阶
- nginx Location匹配规则详解
- nginx rewrite规则详解
- nginx进程模型及相关配置
- nginx分流实战
- Nginx反向代理
- nginx反向代理配置去除前缀
- nginx跨域配置
- nginx缓存以及gzip配置
- 深入理解浏览器缓存
- nginx配置https
- nginx+lua实现nginx高级应用
- lvs+nginx高可用负载均衡
- nginx安装与配置
- Mysql深度优化
- Mysql存储引擎MYISAM和INNODB选择
- mysql共享锁及排它锁
- mysql事务及隔离级别
- mysql底层BTree与B+Tree实现原理
- mysql索引详解
- mysql最全索引优化建议
- sql执行计划explain详解
- Mysql高可用-主从复制
- mysql+keepalive高可用方案操盘实战
- MySQL数据库分库分表方案
- MySQL常见问题解决办法汇总
- mysql函数
- ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
- 递归查询
- 方案1
- 方案2
- 方案3
- 树形结构表3种设计分析
- 树形结构左右值
- MYSQL分布式锁XA实战
- 复杂sql
- 高并发实战
- 系统如何支撑高并发
- 解决高并发问题
- 千万级PV网站架构
- js高级应用实例
- 如何前端显示pdf的base64文件
- vue history模式在nginx环境配置
- webuploader多图上传
- mycat
- Mycat简介
- 工具包
- 如何通过PhpSpreadsheet读取和写入Excel
- 常用方法实现
- php百万级大数据量如何成功并高效导出
- 如何高准确率的下载远程图片到本地
- ase加解密
- php rsa
- tree类
- 获取方法执行内存空间和执行时间
- phpspreadsheet 中文文档(五)节约内存
- pdf生成文字水印
- redis进阶
- 详解Redis中两种持久化机制RDB和AOF,吊打面试官
- redis缓存穿透,缓存击穿,缓存雪崩的解决方法以及代码实现
- 巧用 Bitmap 实现亿级海量数据统计
- 延时队列
- linux应用
- linux tar打包大文件并分割传输另一台linux服务器
- 阿里云服务器如何不关机磁盘扩容
- 基础知识
- linux启动过程
- SIGKILL和SIGTERM、SIGINT
- 解决linux虚拟机不能上网的问题
- vm虚拟机下centos7挂载windows共享目录
- 开机自启配置文件
- elastic
- 什么是Elastic
- 安装并运行Elasticsearch
- kibana实现es数据可视化
- Elasticsearch的“crud”操作
- 简单检索
- 表达式检索
- 全文搜索
- 短语搜索
- 高亮搜索
- 聚合分析
- 区块链
- php实现简易版区块链
- Paxos的通俗理解及其在数据库高可用上的使用
- 桌面开发Electron
- 快速入门
- hello word应用
- 打包并分发hello word应用程序
- 渲染进程显示通知
- docker教程
- 入门
- hello world
- 容器文件
- Dockerfile 文件
- 其他常用命令
- docker微服务
- 搭建lnmp环境
- swoole
- windows安装swoole
- mysql连接池
- 应用实例
- 进程 线程 协程
- 守护进程
- 通过 Supervisor实现php脚本守护进程服务
- swoole是怎么支持php语法的,phpstorm增加Swoole代码智能提示
- phpswoole docker安装
- rabbitmq
- windows10环境下的RabbitMQ安装步骤(图文)
- 教程
- rabbitMq 保证消息可靠性
- thinkphp6使用rabbitmq
- 微服务
- 微服务入门
- php使用Yar实现RPC调用
- 算法
- 斐波拉契
- 文件目录
- thinkphp
- thinkphp 6 消息队列
- 机器学习
- 数据类型
- 均值、中值和众数
- 方差、标准差
- 百分位数
- swoft
- swoft配置连接池
- docker 安装 swoft
- 创建entity
- 中间件
- 模型join
- 模型关联
- 事件
- 打印出swoft的所有sql日志到控制台或者文件
- 事件触发
- 文件
- 下载
- 在浏览器读取文件
- 文件上传
- 验证器
- 非注解式验证
- alias
- excel
- excel保存
- rpc
- phpstorm
- PHPSTORM 与 LINUX 搭建PHP项目运行环境