[Java、Android面试]_01_多线程: 重要参数、状态、优雅停止线程等

本人今年参加了很多面试,也有幸拿到了一些大厂的offer,整理了众多面试资料,后续还会分享众多面试资料,感兴趣的朋友可收藏+关注,
现分享如下:

文章目录

    • 1. 线程池重要参数
    • 2. 线程池状态
    • 3. 优雅停止线程
    • 4. 线程池的好处?线程池类型?

1. 线程池重要参数

public ThreadPoolExecutor(int corePoolSize,  
                           int maximumPoolSize,  
                           long keepAliveTime,  
                           TimeUnit unit,  
                           BlockingQueue<Runnable> workQueue,  
                           ThreadFactory threadFactory,  
                           RejectedExecutionHandler handler) 

(1)corePoolSize: 核心线程数,线程池维护的最小线程数量
线程池维护的最小线程数量,核心线程创建后不会被回收(注意!!设置
allowCoreThreadTimeOut=True后,空闲的核心线程数超过存活时间也会被回收)。
大于核心线程数的线程,在空闲时间超过keepAliveTime后会被回收。
线程池刚创建时,里面没有一个线程,当调用 execute() 方法添加一个任务时,如果正在运行的线程数量小于corePoolSize,则马上创建新线程并运行这个任务。
在这里插入图片描述

(2)maximunPoolSize: 最大线程数
线程池允许创建的最大线程数量。
当添加一个 任务时,核心线程已满,线程池还没有达到最大线程数,并且没有空闲线程,工作队列已满的情况下,就会创建一个新线程并执行。

(3)keepAliveTime: 空闲线程存活时间
当一个可被回收的线程的空闲时间大于keepAliveTime时,该线程就会被回收。
可被回收的线程包含:
1)设置为allowCoreThreadTimeout=True的核心线程
2)大于核心线程数的线程(即:非核心线程)

(4)unit: keepAliveTime的时间单位

1.TimeUnit.NANOSECONDS  
2.TimeUnit.MICROSECONDS  
3.TimeUnit.MILLISECONDS // 毫秒  
4.TimeUnit.SECONDS  
5.TimeUnit.MINUTES  
6.TimeUnit.HOURS  
7.TimeUnit.DAYS  

(5)workQueue: 存放待执行任务的工作队列
当提交的任务数超过核心线程数大小后,再提交的任务就存放在工作队列,任务调度时再从队列中取出任务。它仅仅用来存放被execute()方法提交的Runnable任务。工作队列实现了BlockingQueue接口。
· ArrayBlockingQueue: 基于数组的有界阻塞队列,按FIFO排序。新任务进来后,会放到该队列的队尾,有界的数组可以防止资源耗尽问题。当线程池中线程数量达到corePoolSize后,再有新任务进来,则会将任务放入该队列的队尾,等待被调度。如果队列已经是满的,则创建一个新线程,如果线程数量已经达到maxPoolSize,则会执行拒绝策略。

· LinkedBlockingQueue: 基于链表的无界阻塞队列,按FIFO排序。由于该队列的近似无界性,当线程池中线程数量达到corePoolSize后,再有新任务进来,会一直存入该队列,而不会去创建新线程直到maxPoolSize,因此使用该工作队列时,参数maxPoolSize其实是不起作用的。

· SynchronousQueue: 一个不缓存任务的阻塞队列,生产者放入一个任务必须等到消费者取出这个任务。也就是说,新任务进来时,不会缓存该任务,而是直接被调度执行该任务,如果没有可用线程,则创建新线程;如果线程数量达到maxPoolSize,则执行拒绝策略。

· PriorityBlockingQueue: 具有优先级的无界阻塞队列,优先级通过参数Comparator实现。

(6)ThreadFactory: 线程工厂
创建线程的工厂,可以设定线程名,线程编号

(7)handler: 拒绝策略
当线程池线程数已满,并且工作队列达到限制,新提交的任务使用拒绝策略处理。可以
自定义拒绝策略,拒绝策略需要实现RejectedExecutionHandler接口。
JDK默认的拒绝策略有四种:
· AbortPolicy: 丢弃任务并抛出RejectedExecutionException异常。
· DiscardPolicy: 丢弃任务,但是不抛出异常。可能导致无法发现系统的异常状态。
· DiscardOldestPolicy: 丢弃队列最前面的任务,然后重新提交被拒绝的任务。
· CallerRunsPolicy: 由调用线程处理该任务。

线程执行流程:
在这里插入图片描述

2. 线程池状态

在这里插入图片描述

3. 优雅停止线程

开启线程可以使用start()方法,停止线程的方法有:
(1)stop(): 不建议使用
但不建议stop方法,因为stop()相对粗暴,一旦调用stop(),就会直接停掉线程,这样就存在严重问题,比如:任务执行到哪一步?该释放的锁释放了吗?
需要强调的是:stop()会释放线程占用的synchronized锁,而不会自动释放ReentrantLock锁。

(2)通过中断的方式interrupt:推荐使用
可以使用interrupt()的方式,来优雅的控制线程暂停。如下代码:
在这里插入图片描述
可以通过interrupt()的方式来控制子线程是否终止,子线程也可以根据信号来终止线程了。

4. 线程池的好处?线程池类型?

线程池的好处:
(1)降低资源消耗:通过重复利用已创建的线程,降低线程创建和销毁造成的资源消耗;
(2)提高响应速度:当任务到达时,任务可以不需要线程创建即可立即执行;
(3)提高线程的可管理性:线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以同一分配、调优和监控。

四种线程类型:
(1)newCachedThreadPool:适用短期异步任务
创建一个可缓存线程池,当线程池的数量过大,它可以有效回收多余的线程,如果线程数量不足,那么它可以创建新的线程。
优点:复用率较高,如果第二个任务开始时,第一个任务已经结束,则第二个任务会服用第一个任务的线程,而不会重开线程;
不足:虽然可以根据业务自动扩展线程数来拓展业务,但是最多需要多少个线程同时处理确是我们无法控制的。

(2)newFixedThreadPool:适用长期异步任务
创建一个定长的线程池,可控制线程最大并发数,超出的线程会在队列中等待;

(3)newScheduleThread:适用周期性任务
创建一个可定期或延时执行的定长线程池,支持定时和周期性执行任务;
创建一个固定大小的线程池,线程池内线程存活时间无限制,线程池可以支持定时及周
期性任务执行,如果所有线程均处于繁忙状态,对于新任务会进入DelayedWorkQueue队列中,这是一种按照超时时间排序的队列结构

(4)newSingleThreadExcutor:适用按顺序执行任务
创建一个单线程的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指
定顺序(FIFO, LIFO,优先级)进行执行。

多线程篇完结,撒花!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/452660.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

重载和覆盖以及隐藏有什么区别?

重载和重写以及重新定义&#xff08;隐藏&#xff09;有什么区别&#xff1f; 1.重载 重载是在一个作用域内进行的&#xff0c;多定义几个参数列表(参数类型和参数个数)不同但同名方法&#xff0c;这种叫做重载。重载通常发生在一个类内。 如: class Demo {void func() { ..…

在Linux/Ubuntu/Debian中设置字体

下载字体。 下载你喜欢的字体&#xff0c;双击并安装。 之后更新字体缓存&#xff1a; fc-cache -f -v安装 GNOME 调整。 GNOME Tweaks 是一个工具&#xff0c;允许你自定义 GNOME 桌面环境的各个方面&#xff0c;包括字体。 如果你还没有安装 GNOME Tweaks&#xff1a; …

「飞桨星河社区创作者激励计划」全新上线!丰富权益,等你领取~

为了助力更多的创作者实现在飞桨星河社区的成长&#xff0c;同时鼓励创作者们积极投入&#xff0c;记录创作者们的高光时刻&#xff0c;重磅推出**「创作者成长体系」&#xff0c;同时推出「每周精选&月度榜单」**活动&#xff0c;期待你一同加入精彩纷呈的AI学习与创作之旅…

【网络原理】TCP 协议中比较重要的一些特性(二)

目录 1、TCP 状态转换 1.1、三次握手状态 1.2、四次挥手状态 2、滑动窗口 3、流量控制 1、TCP 状态转换 TCP 状态和“线程状态”是类似的概念&#xff0c;用于描述 TCP 连接过程中正在执行什么操作。 TCP 服务器和客户端都有一定的数据结构来保存连接信息&#xff0c;而…

C++day2——引用、结构体、类

思维导图&#xff1a; 2、自己封装一个矩形类(Rect)&#xff0c; 拥有私有属性&#xff1a;宽度(width)、高度(height)&#xff0c; 定义公有成员函数初始化函数:void init(int w, int h) 更改宽度的函数:set_w(int w)更改高度的函数:set_h(int h) 输出该矩形的周长和面积函…

4款支持局域网环境使用的办公软件,可免费试用

在局域网环境下&#xff0c;选择一款合适的办公软件能极大提升团队协作效率。今天就为大家推荐4款支持局域网环境使用&#xff0c;且可免费试用的办公软件&#xff0c;分别是小鱼易连、有度即时通、石墨文档和坚果云。 一、小鱼易连 小鱼易连是一款高效的视频会议软件&#xff…

考察1学生学籍系统winform .net6 sqlserver

考察1学生学籍系统winform .net6 sqlserver 下载地址: 考察1学生学籍系统winform .net6 sqlserver winform(.net6)sqlserver数据库 只有数据库的表结构需要自己建表 启动程序 登录失败 进入主界面 项目获取&#xff1a; 项目获取&#xff1a;typora: typora/img (gitee.com…

idea Springboot 组卷管理系统LayUI框架开发mysql数据库web结构java编程计算机网页

一、源码特点 springboot 组卷管理系统是一套完善的完整信息系统&#xff0c;结合mvc框架和LayUI框架完成本系统springboot spring mybatis &#xff0c;对理解JSP java编程开发语言有帮助系统采用springboot框架&#xff08;MVC模式开发&#xff09;&#xff0c;系统具有完整…

无人机远程指挥控制系统技术,无人机远程指挥中心功能详解

无人机远程指挥控制系统是一种用于实现无人机远程控制和指挥的技术。它主要基于先进的通信技术和无人机控制技术&#xff0c;使得操作人员可以在远离无人机的地方对其进行实时的控制和监控。 无人机远程指挥控制系统关键部分&#xff1a; 1. 通信技术&#xff1a;这是无人机远…

2023年对我国精油品牌战略以及行业分析

环洋咨询Global Info Research的精油市场调研报告提供精油市场的基本概况&#xff0c;包括定义&#xff0c;分类&#xff0c;应用和产业链结构&#xff0c;同时还讨论发展政策和计划以及制造流程和成本结构&#xff0c;分析精油市场的发展现状与未来市场趋势&#xff0c;并从生…

<.Net>VisaulStudio2022下用VB.net实现socket与汇川PLC进行通讯案例(Eazy521)

前言 此前&#xff0c;我写过一个VB.net环境下与西门子PLC通讯案例的博文&#xff1a; VisaulStudio2022下用VB.net实现socket与西门子PLC进行通讯案例&#xff08;优化版&#xff09; 最近项目上会用到汇川PLC比较多&#xff0c;正好有个项目有上位机通讯需求&#xff0c;于是…

Linux - 多线程

1、Linux线程概念 1.1、什么是线程 在一个程序里的一个执行路线就叫做线程&#xff08;thread&#xff09;。更准确的定义是&#xff1a;线程是 “一个进程内部的控制序列”一切进程至少都有一个执行线程&#xff1b;线程在进程内部运行&#xff0c;本质是在进程地址空间内运…

娃哈哈大广赛命题内容详解,优胜作品分享!

2024第16届全国大学生广告艺术大赛正在火热进行中&#xff0c;你参加了吗&#xff01;大广赛是中国最大的高校广告创意竞赛活动。它由教育部高等教育司指导&#xff0c;中国传媒大学、大广赛文化传播&#xff08;北京&#xff09;有限公司共同举办&#xff0c;至今已经发布了多…

1679.K和数对的最大数目

题目&#xff1a;给你一个整数数组nums和一个整数k。 每一步操作中&#xff0c;你需要从数组中选出和为 k 的两个整数&#xff0c;并将他们移出数组。 返回你可以对数组执行的最大操作数。 解题思路&#xff1a;排序&#xff0b;双指针 class Solution{public int maxOperat…

第 5 章 TF坐标变换(自学二刷笔记)

重要参考&#xff1a; 课程链接:https://www.bilibili.com/video/BV1Ci4y1L7ZZ 讲义链接:Introduction Autolabor-ROS机器人入门课程《ROS理论与实践》零基础教程 5.1.6 TF坐标变换实操 需求描述&#xff1a; 程序启动之初&#xff1a;产生两只乌龟&#xff0c;中间的乌龟…

Docker部署系列之Docker Compose安装Redis三主三从集群

在日常开发或者编程当中&#xff0c;经常需要用到redis集群&#xff0c;若是按照传统的方式&#xff0c;一个机器一个机器搭建&#xff0c;难免过于繁琐&#xff0c;故而可以通过dock er-compose编排方式&#xff0c;快速搭建。我在搭建过程当中&#xff0c;将操作记录下来&…

『运维备忘录』之 iptables 防火墙使用指南

前言 iptables 是一个配置 Linux 内核防火墙的命令行工具&#xff0c;它是用来设置、维护和检查Linux内核的IP包过滤规则的。本文将介绍 iptables 的基础知识和使用示例。 注意&#xff1a;红帽/红旗/CentOS等 7 版本以上已改为使用 firewalld 作为防火墙替换iptables。 一、基…

sqllab第三关通关笔记

知识点&#xff1a; 通过回显的信息判断原始语句的组成猜测该语句为 select 1,2,3 from 表名 where id (输入) limit 0,1 首先通过测试判断存在什么类型的sql注入 构造id1/0 发现正常输出&#xff1b;说明是字符型的sql注入 好了&#xff0c;下面就测试有什么限制条件 构造…

4、设计模式之建造者模式

一、什么是建造者模式 建造者模式是一种创建型设计模式&#xff0c;也叫生成器模式。 定义&#xff1a;封装一个复杂对象构造过程&#xff0c;并允许按步骤构造。 解释&#xff1a;就是将复杂对象的创建过程拆分成多个简单对象的创建过程&#xff0c;并将这些简单对象组合起来…

大路灯有必要买吗?测评师推荐五大大路灯品牌!

不知道各位家长有没有发现&#xff0c;近几年来小小年纪就戴眼镜的孩子真的越来越多了&#xff01; 根据专家数据统计&#xff0c;在全国青少年近视率中小学生就占其40%比重&#xff0c;也代表了10个学生中就有4、5个是戴眼镜的。造成这个趋势的原因也不难理解&#xff0c;一是…
最新文章