进程、线程、协程

简介: 面试官:简单聊一下进程、线程、协程的区别吧。。。

进程

读书那会学linux时书本上都会写一句非常经典的话,进程是系统资源分配和调度的基本单位。也不理解啥意思,纯背概念,反正老师说考试会考。导致只对这一句话印象特别深刻。


程序是指令、数据及其组织形式的描述,进程是程序的载体。程序本身是没有生命周期的,只是存在于磁盘上的一些指令集合,但程序一旦被运行起来就是进程。启动后的进程会依赖操作系统的调度完成生命周期的转换。


无论操作系统是单核系统还是多核系统,看起来似乎一个CPU在并行的调度多个进程,其实只是操作系统背后的调度逻辑来通过切换上下文来实现的并发执行,本质上在某一时刻一个CPU只能执行一个进程。只不过切换时间片特别短让我们认为是在并行执行。


并发: 同一时刻只有一个进程/线程运行,其余都阻塞等待调度

并行: 同一时刻有多个进程/线程同时运行


线程

线程为程序调度的最小单位,也就是说一个进程中可以包含多个线程,线程状态也是交由操作系统调度。线程的状态分为新建状态、运行状态、阻塞状态、就绪状态、终止状态,线程之间的切换和进程一样也需要系统进行上下文切换完成。


各个语言的线程概念只是对操作对象中的线程做了一层封装,提供的各个api本质上也是对接操作系统api,由于线程的调度需要操作系统来进行上下文切换资源消耗比较猛。所以出现了更加轻量级的协程。


协程

协程是一种更加轻量级调度单位,协程不被操作系统内核所管理而完全是由程序所控制。

image.png

之所以轻量级也是因为避免操作系统频繁的从用户空间切换到内核空间进行调度的资源消耗,直接在用户空间的代码中管理协程的声明周期,适用于大量并发下的IO事件,这也是Golang风靡全球的原因之一。


总结

进程与线程对比

  1. 线程的创建或销毁的代价比进程小且上下文切换的速度比进程快,需要频繁创建、销毁或大量计算时应优先选用线程
  2. 线程在CPU上的使用效率更高,需要多核分布时优先选用线程,需要多机分布时优先选用进程
  3. 线程的安全性、稳定性没有进程好,需要更稳定安全时优先使用进程。


线程与协程对比

  1. 线程属于操作系统内核管理调度,而协程属于用户空间代码中自己管理的轻量级线程。
  2. 线程运行状态切换及上下文切换需要内核调度,会消耗系统资源;而协程完全由程序控制,状态切换及上下文切换不需要内核参与。





相关文章
|
1天前
|
调度
进程和线程的区别和联系
进程和线程的区别和联系
4 0
|
1天前
|
算法 调度
【操作系统】处理机调度的基本概念和三个层次、进程调度的时机和方式、调度器、闲逛线程
【操作系统】处理机调度的基本概念和三个层次、进程调度的时机和方式、调度器、闲逛线程
10 3
|
1天前
|
消息中间件 安全 调度
基于Python的性能优化(线程、协程、进程)
一、多线程 在CPU不密集、IO密集的任务下,多线程可以一定程度的提升运行效率。
|
2天前
|
存储 调度
进程和线程之间的区别和联系
进程和线程之间的区别和联系
8 0
|
3天前
|
Java 调度
【JAVA学习之路 | 提高篇】进程与线程(Thread)
【JAVA学习之路 | 提高篇】进程与线程(Thread)
|
3天前
|
监控 数据可视化 Java
Python中的线程池与进程池
【5月更文挑战第19天】本文探讨Python中提高程序性能的关键——线程池和进程池。线程池与进程池是并行编程工具,有效利用多核处理器,加速程序执行。线程是运算调度单位,进程是资源分配和调度基础。线程池与进程池管理线程和进程,减少创建销毁开销。
14 0
|
8天前
|
Android开发 Kotlin API
Android插件化探索与发现,kotlin协程切换线程
Android插件化探索与发现,kotlin协程切换线程
|
9天前
|
Java 测试技术 Python
Python的多线程允许在同一进程中并发执行任务
【5月更文挑战第17天】Python的多线程允许在同一进程中并发执行任务。示例1展示了创建5个线程打印"Hello World",每个线程调用同一函数并使用`join()`等待所有线程完成。示例2使用`ThreadPoolExecutor`下载网页,创建线程池处理多个URL,打印出每个网页的大小。Python多线程还可用于线程间通信和同步,如使用Queue和Lock。
30 1
|
9天前
|
数据处理 Python
Python并发编程:实现高效的多线程与多进程
Python作为一种高级编程语言,提供了强大的并发编程能力,通过多线程和多进程技术,可以实现程序的并发执行,提升系统的性能和响应速度。本文将介绍Python中多线程和多进程的基本概念,以及如何利用它们实现高效的并发编程,解决实际开发中的并发性问题。
|
3天前
|
存储 缓存 Linux
【Linux】进程概念(冯诺依曼体系结构、操作系统、进程)-- 详解
【Linux】进程概念(冯诺依曼体系结构、操作系统、进程)-- 详解