多线程和多进程

进程和线程

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

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

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

什么是多进程?

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

什么是多线程?

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

多进程和多线程如何选择

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

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

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

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

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

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

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

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

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

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

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

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

相关推荐
七夜zippoe1 分钟前
Python网络编程实战:从TCP/IP到WebSocket的协议演进与核心技术解析
网络·python·websocket·tcp/ip·socket·心跳机制
Selenium-Wang2 分钟前
静态IP是什么意思?一文解析原理、用途与优势
网络·网络协议·tcp/ip
礼拜天没时间.7 分钟前
《Docker实战入门与部署指南:从核心概念到网络与数据管理》:初识Docker——概念与优势
linux·运维·网络·docker·容器·centos
雅菲奥朗8 分钟前
工信部教考中心《系统可靠性工程师(高级)》开课通知
运维·sre
阿钱真强道8 分钟前
05 thingsboard-4.3-ubuntu20-rk3588-部署
linux·运维·服务器·鸿蒙
驱动探索者9 分钟前
Intel Xeon 服务器 CPU 学习
运维·服务器·学习·xeon
YYYing.9 分钟前
【计算机网络 | 第十一篇】计网之应用层(二)—— 万字解析 + 图解DNS、DHCP、HTTP2.0/3.0
网络·网络协议·计算机网络·http
夜颂春秋10 分钟前
重温Linux命令
linux·运维·职场和发展·单元测试
Sheep Shaun11 分钟前
Linux 环境搭建终极指南(Ubuntu 版):2026 最新版,适配 Ubuntu 24.04 LTS
linux·运维·服务器·ubuntu
小李独爱秋13 分钟前
计算机网络经典问题透视:物联网和M2M通信的关系是怎样的?
运维·服务器·网络·物联网·计算机网络·m2m