python与多进程和多线程

1.进程和线程的关系

根本区别:进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位

在开销方面:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做进程的一部分,同个进程中的线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。

所处环境:在操作系统中能同时运行多个进程(程序);而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行

内存分配方面:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。

包含关系:没有多个线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分。

资源消耗:线程可以暴力的看成轻量级的进程,所以cpu(创建/切换)进程/线程,维护进程/线程等时,线程所需要消耗的资源都比进程少。

通信:进程之间通讯比较麻烦,需要以通信的方式(IPC)进行;而线程之间就比较简单了。

安全性:多进程,若挂了一个进程,其他进程无所谓;多线程,过了一个线程,所有线程GG。

2.python多进程/线程

import multiprocessing as mp #多进程
import threading as td #多线程

猜你喜欢

转载自blog.csdn.net/weixin_44414593/article/details/107143697