头部左侧文字
头部右侧文字
当前位置:网站首页 > 资讯 > 正文

创建线程池的,创建线程池的方式有哪些

作者:admin日期:2024-02-14 08:15:12浏览:65分类:资讯

什么是线程池?为什么要使用线程池?如何使用?

从源码可以看出,这种线程池只有一个核心线程,并且总线程数为 1。具体使用如下:一种核心线程数量固定,非核心线程数不固定的线程池。

线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。

线程池作用就是限制系统中执行线程的数量。根据系统的环境情况,可以自动或手动设置线程数量,达到运行的最佳效果;少了浪费了系统资源,多了造成系统拥挤效率不高。用线程池控制线程数量,其他线程排队等候。

线程池,从名字的表明含义上我们知道线程池就是包含线程的一个池子,它起到新建线程、管理线程、调度线程等作用。既然Android中已经有了线程的概念,那么为什么需要使用线程池呢?我们从两个方面给出使用线程池的原因。

线程池是一种“池化”的线程使用模式,通过创建一定数量的线程,让这些线程处于就绪状态来提高系统响应速度,在线程使用完成后归还到线程池来达到重复利用的目标,从而降低系统资源的消耗。

线程池创建的四种

FixedThreadPool:固定大小的线程池。该线程池创建一定数量的线程来执行任务。CachedThreadPool:缓存线程池。该线程池创建的线程数量不固定,当有新任务需要执行时,会创建新的线程来执行任务。

固定大小的线程池、缓存线程池、单线程线程池、定时任务线程池。固定大小的线程池创建一定数量的线程来执行任务,当线程处于空闲状态时,也不会被回收。适用于需要限制线程数量的情况,如服务器端接受客户端请求的场景。

newFixedThreadPool:创建的是定长的线程池,可以控制线程最大并发数,超出的线程会在线程队列中等待,使用的是无界队列,核心线程数和最大线程数一样,当线程池中的线程没有任务时候立刻销毁,使用默认线程工厂。

线程池创建的4种方式与参数详解

newScheduedThreadPool 创建一个定长的线程池,而且支持定时的以及周期性的任务执行,支持定时及周期性任务执行。

FixedThreadPool:固定大小的线程池。该线程池创建一定数量的线程来执行任务。CachedThreadPool:缓存线程池。该线程池创建的线程数量不固定,当有新任务需要执行时,会创建新的线程来执行任务。

固定大小的线程池、缓存线程池、单线程线程池、定时任务线程池。固定大小的线程池创建一定数量的线程来执行任务,当线程处于空闲状态时,也不会被回收。适用于需要限制线程数量的情况,如服务器端接受客户端请求的场景。

Java中4种线程池 Java通过Executors提供四种线程池,分别为:newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。

ThreadPoolExecutor类是Java中的一个内置类,它可以用于创建和管理线程池。这个类提供了很多有用的方法和属性,例如可以指定线程池的大小、最大线程数、线程空闲时间等参数。

暂无评论,来添加一个吧。

取消回复欢迎 发表评论: