多线程和多进程

进程和线程

进程:一个正在执行的程序,是操作系统资源分配的最小单位。

线程:线程有时又称为轻量级进程,是程序执行的最小单位,系统独立调度和分派CPU的基本单元,它是进程中的一个实体。

进程就是运行中的程序,线程就是像线一样细的进程,是程序执行的最小单位,也被叫做轻量级的进程。

什么是多进程?

多进程就是指计算机同时执行多个进程,一般是同时运行多个软件。

什么是多线程?

多线程就是指一个进程中同时有多个线程正在执行,线程不拥有系统资源故使用线程调度时系统开销小。

多进程和多线程如何选择

下面把进程比作"桌子",把线程比作"椅子",方便理解。

单进程单线程:一个人在一个桌子上吃菜。

单进程多线程:多个人在同一个桌子上一起吃菜。

多进程单线程:多个人每个人在自己的桌子上吃菜。

对于Windows来说,增加"桌子"需要的开销很大,所以Windows鼓励多个人在同一个桌子上一起吃菜,即单进程多线程 ;对于Linux来说,增加"桌子"需要的开销,所以Linux鼓励多个人每个人在自己的桌子上吃菜,即多进程单线程,但是Linux的多进程又带来了新的问题,那就是进程间通信不方便,所以Linux需要进程间通讯的方法。

多线程和多进程有什么区别?

多线程的共享数据:多个线程可能会同时处理多个资源,这就是多线程的共享数据。

多线程的同步数据:同步就是指多个线程在在同一个时间段内只能一个线程执行指定代码,其他线程要在此线程完成之后才能继续执行。

数据方面:多进程数据是分开的,共享复杂,同步简单;多线程数据是一起的,共享简单,同步复杂。

内存方面:多进程占用内存多,利用率低;多线程占用内存少,利用率高。

创建销毁切换方面:多进程复杂速度慢;多线程简单快。

可靠性方面:进程间不相互影响;一个线程挂掉会导致整个进程挂掉。

相关推荐
Darling噜啦啦4 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
swipe4 小时前
正则表达式入门到进阶:从表单校验到手写模板引擎
前端·javascript·面试
神奇小汤圆5 小时前
RAG大厂面试题汇总:向量检索、混合检索、Rerank、幻觉处理高频问题
面试
假如让我当三天老蒯7 小时前
回归基本功:Map/Set 与 WeakMap/WeakSet 的区别
前端·面试
假如让我当三天老蒯11 小时前
回归基本功!前端的解构赋值、扩展运算符、剩余参数
前端·面试
Mr_愚人派11 小时前
当"Claude"不再是 Claude:一次第三方 API 代理引发的 AI 身份伪造排查实录
人工智能·安全
Lee川11 小时前
Memory 模块深度解析(面试向)
人工智能·面试
大树881 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠1 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质1 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务