Python中的线程池是什么

线程池传统多线程问题?传统多线程方案会使用“即时创建, 即时销毁”的策略。尽管与创建进程相比,创建线程的时间已经大大的缩短,但是如

多线程的做法是,可以同时创建多个线程放入等待执行的序列中。某个线程执行完毕就将它从序列中移除并销毁。不然的话,即时创建,然后就一定要等到它销毁,那这不是多线程,这是单线程.
进程中根据需要,为一些需要慢资源、竟争性资源的任务创建线程,排除等候执行。
线程需要等待分配,如果短时间建立了多个线程,哪个线程先开始执行,由调度程序决定;
...调度>>>执行>>>循环
当线程执行完毕,销毁线程。
比如说,下载图片:我有一个列表,记录了要下载的300张图片的URL。每个图片的来源可能是不同网站(服务器)。那么,主循环里只需要创建300个【下载】线程。每个线程负责一个URL的下载任务。
然后,调序程序开始调度:线程1有数据过来了,分配时间片给线程1处理这段数据...线程n执行完毕,销毁线程n...线程1又有数据过来了,分配时间片给线程1处理这段数据......销毁线程n,没有等待中的线程,调度暂停。
于是,所有的图片下载完了。
这个过程与单线程的不同是,在多线程中,最开始同一时间有300个请求在等待若干个服务器返回数据,而单线程则总是只有一个请求在等待服务器返回数据或者正在处理数据,另外299个请求根本不存在。
这才是多线程与单线程最主要的差别:在等待某个资源的时候,把其它资源给别的线程去使用。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2020-09-29
线程,有时被称为轻量级进程(Lightweight Process,LWP),是程序执行流的最小单元。一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成。另外,线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。一个线程可以创建和撤消另一个线程,同一进程中的多个线程之间可以并发执行。由于线程之间的相互制约,致使线程在运行中呈现出间断性。线程也有就绪、阻塞和运行三种基本状态。就绪状态是指线程具备运行的所有条件,逻辑上可以运行,在等待处理机;运行状态是指线程占有处理机正在运行;阻塞状态是指线程在等待一个事件(如某个信号量),逻辑上不可执行。每一个程序都至少有一个线程,若程序只有一个线程,那就是程序本身。
线程是程序中一个单一的顺序控制流程。进程内有一个相对独立的、可调度的执行单元,是系统独立调度和分派CPU的基本单位指令运行时的程序的调度单位。在单个程序中同时运行多个线程完成不同的工作,称为多线程。