当前位置: 首页 > news >正文

多线程面试合集

前言

前文介绍了JVM相关知识,本文将重点介绍多线程相关知识以及工作中的一些经验。

多线程面试合集

  1. 什么是多线程?为什么我们需要多线程?

多线程是指在一个进程中同时执行多个线程,每个线程可以执行不同的任务。多线程可以提高程序的执行效率,充分利用多核CPU的计算能力,同时处理多个任务。

  1. 在Java中创建线程有几种方式?

继承Thread类并重写run()方法;
实现Runnable接口并重写run()方法;
实现Callable接口并重写call()方法,这种方式通常与线程池一起使用。

  1. 解释一下线程的生命周期?

线程的生命周期包括新建、就绪、运行、阻塞和死亡五个状态。新建状态表示线程已被创建但尚未启动;就绪状态表示线程已准备好运行,等待CPU调度;运行状态表示线程正在执行;阻塞状态表示线程由于某种原因暂时停止执行;死亡状态表示线程执行完毕或出现异常而结束。

  1. 什么是线程安全?Java中如何实现线程安全?

线程安全是指在多线程环境下,程序的执行结果不会因为线程的调度顺序而改变。Java中实现线程安全的方式有多种,如使用synchronized关键字、使用Lock接口及其实现类、使用volatile关键字、使用原子类、使用线程安全的集合类等。

  1. 什么是死锁?如何避免死锁?

死锁是指两个或多个线程互相等待对方释放资源而无限期地等待下去。避免死锁的方法包括:
避免一个线程同时获取多个锁;
按照固定的顺序获取锁;
使用定时锁,即尝试获取锁,若超过一定时间则放弃;
使用死锁检测工具来检测和恢复死锁。

  1. 解释一下synchronized关键字和Lock接口的区别?

synchronized关键字和Lock接口都可以用来实现线程同步,但它们在使用方式和功能上有所不同。synchronized是Java语言的关键字,它可以修饰方法或代码块,实现线程同步;而Lock接口是Java.util.concurrent包中的一个接口,它提供了更灵活的线程同步机制,如支持可重入锁、可中断获取锁、尝试获取锁等。

  1. 解释一下AQS?

AQS,即AbstractQueuedSynchronizer,是Java中的一个抽象队列同步器类。它是Java并发编程中的一个重要组成部分,广泛用于实现ReentrantLock、Semaphore、CountDownLatch等同步工具类
AQS的核心思想是利用一个先进先出(FIFO)的双向队列来管理线程的竞争和等待。AQS提供了两种模式:独占模式和共享模式。独占模式是指只有一个线程可以持有同步状态,如ReentrantLock;共享模式是指多个线程可以同时持有同步状态,如Semaphore。
AQS的具体实现方式是通过维护一个volatile变量state表示同步状态。当state为0时表示没有线程占用同步状态,当state为1时表示有一个线程占用同步状态。当多个线程竞争同步状态时,只有一个线程可以成功占用同步状态,其余线程将加入到AQS的同步队列中等待。当占用同步状态的线程释放同步状态时,AQS会从同步队列中选择一个线程唤醒,使其重新尝试获取同步状态。
AQS提供了一些核心方法,如acquire(int arg)尝试获取同步状态,如果获取失败则加入同步队列并阻塞等待唤醒,直到获取同步状态成功。tryAcquire(int arg)尝试获取同步状态,如果获取成功则返回true,否则返回false。release(int arg)释放同步状态,通知其他线程可以尝试获取同步状态。
总的来说,AQS提供了一种高效且灵活的实现同步器的方式,可以满足不同的并发编程需求。

  1. 什么是线程池?为什么要使用线程池?

线程池是一种管理和复用线程的技术,它可以避免频繁地创建和销毁线程,提高程序的性能。使用线程池的好处包括:
降低资源消耗:通过复用已创建的线程,减少在创建和销毁线程上花费的时间以及系统资源的开销;
提高响应速度:当任务到达时,任务可以不需要等到线程创建就能立即执行;
提高线程的可管理性:线程池可以进行统一的分配、调优和监控。

  1. 介绍一下Java中的几种线程池及其应用场景?

Java中的线程池主要包括FixedThreadPool、CachedThreadPool、SingleThreadExecutor和ScheduledThreadPool等。FixedThreadPool适用于处理CPU密集型任务,控制线程最大并发数;CachedThreadPool适用于处理大量短时间任务,线程数会根据任务量动态调整;SingleThreadExecutor适用于需要保证顺序地执行各个任务,并且在任意时间点,不会有多个线程是活动的场景;ScheduledThreadPool适用于需要定时执行或周期性执行任务的场景。
在真实的应用环境下我们一般都自定义ThreadPoolExecutor,并且没有通用的配置,要根据任务执行时间、CPU处理能力等因素综合考虑,具体的需要结合压测进行评估。

  1. ThreadLocal家族

ThreadLocal 是 Java 中的一个类,它提供了线程本地变量。这些变量与普通变量不同,因为每个访问变量的线程都有自己的独立初始化的变量副本。ThreadLocal 实例通常是类中的私有静态字段,它们为使用该变量的每个线程都持有一个独立的值。
ThreadLocal 的主要作用是提供线程内的数据隔离,避免多线程环境下的数据竞争和不一致问题。每个线程都可以独立地改变自己的副本,而不会影响其他线程所持有的副本。
以下是 ThreadLocal 的一些关键点:
线程隔离:最重要的特性,确保变量对每个线程都是独立的。
避免同步:由于数据是隔离的,因此不需要使用 synchronized 关键字来同步访问。
初始值:可以通过覆盖 initialValue() 方法来为 ThreadLocal 变量设置初始值。
内存泄漏风险:如果不正确地使用 ThreadLocal(例如,长时间持有对象引用而不清理),可能会导致内存泄漏。特别是在使用线程池时,因为线程池中的线程通常不会被销毁,所以它们的 ThreadLocal 变量也不会被垃圾收集。
不适用于所有场景:ThreadLocal 适用于需要在单个线程内维护状态的情况,但不适用于需要在多个线程之间共享数据的场景。
如上文,ThreadLocal仅用于单线程场景
在父子线程场景下,我们要使用InheritableThreadLocal,原理是在new Thread的过程中将数据下传
在多线程场景下,我们要使用TransmittableThreadLocal,在主线程向子线程传递数据。具体的原理主要通过传输器在主线程捕捉数据并在子线程回放快照。

  1. 在使用线程池时有哪些经验?以及遇到过哪些问题?

使用经验:**在配置线程池参数要综合考虑CPU核数、单任务耗时等因素。**不可笼统的按照经验配置,这样可能在一般场景下不会出现什么问题,但是在大流量场景下会爆发出一系列问题:如jvm无法承载达到的流量导致阻塞、任务积压导致服务假死重启等。在配置好参数之后,最好通过压测进行目前性能的测试,并配置服务接口的限流,以防实际情况压垮服务。在业务场景中,要进行线程隔离,以防调用不均衡导致资源分配侵袭影响核心流程。
常见问题:1. 配置线程数、队列数太少,在回传调用线程拒绝策略下,如有突发流量会导致主线程阻塞,长时间持续会压垮服务。2. 线程数配置太多,导致CPU负载高,处理能力下降 3. 队列配置太大导致任务积压在队列中,无法消费,从而影响某些核心节点甚至导致内存溢出。4. 核心任务可配置拒绝策略为Call并限流,不能任其大流量进入、突发场景下最好配置拒绝策略为丢弃,以防导致调用线程阻塞 5. 最好重写拒绝策略,并配置监控告警、同时命名业务线程池。

相关文章:

多线程面试合集

前言 前文介绍了JVM相关知识,本文将重点介绍多线程相关知识以及工作中的一些经验。 多线程面试合集 什么是多线程?为什么我们需要多线程? 多线程是指在一个进程中同时执行多个线程,每个线程可以执行不同的任务。多线程可以提高…...

从微服务到云原生

很多文章介绍云原生概念,说它包含微服务,又包含了其它几个方面的东西,还扯到文化层面、组织层面和技术层面,搞技术的人一听到公司文化问题和组织部门问题,就十分地晕眩,不能让我好好地坐下来写写代码、搞搞…...

bxCAN 主要特性

bxCAN 主要特性 ● 支持 2.0 A 及 2.0 B Active 版本 CAN 协议 ● 比特率高达 1 Mb/s ● 支持时间触发通信方案 发送 ● 三个发送邮箱 ● 可配置的发送优先级 ● SOF 发送时间戳 接收 ● 两个具有三级深度的接收 FIFO ● 可调整的筛选器组: — CAN1 和…...

武忠祥2025高等数学,基础阶段的百度网盘+视频及PDF

考研数学武忠祥基础主要学习以下几个方面的内容: 1.微积分:主要包括极限、连续、导数、积分等概念,以及它们的基本性质和运算方法。 2.线性代数:主要包括向量、向量空间、线性方程组、矩阵、行列式、特征值和特征向量等概念,以及它们的基本…...

用JavaFX写了一个简易的管理系统

文章目录 前言正文一、最终效果1.1 主页面1.2 动物管理页面-初始化1.3 动物管理页面-修改&新增1.4 动物管理页面-删除&批量删除 二、核心代码展示2.1 启动类2.2 数据库配置-db.setting2.3 日志文本域组件2.4 自定义表格视图组件2.5 自定义分页组件2.6 动物管理页面2.7 …...

第二百九十回

文章目录 1. 概念介绍2. 方法与细节2.1 实现方法2.2 具体细节 3. 示例代码4. 内容总结 我们在上一章回中介绍了"如何混合选择多个图片和视频文件"相关的内容,本章回中将介绍如何通过相机获取视频文件.闲话休提,让我们一起Talk Flutter吧。 1. …...

bert实现完形填空简单案例

使用 bert 来实现一个完形填空的案例,使用预训练模型 bert-base-chinese ,这个模型下载到跟代码同目录下即可,下载可参考:bert预训练模型下载-CSDN博客 通过这个案例来了解一下怎么使用预训练模型来完成下游任务,算是对…...

Jmeter 分布式测试

Jmeter单机进行压测,受到单台机器的性能影响,Jmeter支持分布式测试,用一个控制节点去控制多个工作节点去模拟更多的用户。 版本信息 内容版本号JDK1.8Jmeter5.6.2 分布式测试原理 jmeter 官网对分布式测试有说明,jmeter分布式…...

在 Ubuntu 上安装 Docker Engine

系列文章目录 前言 要在 Ubuntu 上开始使用 Docker Engine,请确保满足先决条件,然后按照安装步骤进行操作。 一、先决条件 注意事项 如果您使用 ufw 或 firewalld 管理防火墙设置,请注意当您使用 Docker 暴露容器端口时,这些端口…...

Mac安装nvm,安装多个不同版本node,指定node版本

一.安装nvm brew install nvm二。配置文件 touch ~/.zshrc echo export NVM_DIR~/.nvm >> ~/.zshrc echo source $(brew --prefix nvm)/nvm.sh >> ~/.zshrc三.查看安装版本 nvm -vnvm常用命令如下:nvm ls :列出所有已安装的 node 版本nvm…...

【开源】基于JAVA+Vue+SpringBoot的智慧家政系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块三、系统展示四、核心代码4.1 查询家政服务4.2 新增单条服务订单4.3 新增留言反馈4.4 小程序登录4.5 小程序数据展示 五、免责说明 一、摘要 1.1 项目介绍 基于微信小程序JAVAVueSpringBootMySQL的智慧家政系统&#xff0…...

Python NLP深度学习进阶:自然语言处理

自然语言处理(Natural Language Processing,NLP)是人工智能领域中的一个重要分支,涉及到处理和理解人类语言的方法和技术。随着深度学习的快速发展,NLP的研究和应用也在不断进步。 在Python中,有许多强大的…...

STM32单片机基本原理与应用(三)

矩阵键盘工作原理 矩阵键盘由多个独立按键组成,按键的一端接地,一端接MCU的GPIO。当按键没有被按下时,电路其实是一个断路,将单片机该引脚设置成输入上拉状态,读到的电平为高电平。当按下按键时,引脚会被拉…...

Android studio布局详解

文章目录 一、Android studio布局详解二、Android studio六大布局案例三、优缺点四、热门文章 一、Android studio布局详解 Android Studio是一种用于开发Android应用程序的集成开发环境(IDE),用于设计和编辑Android应用程序的用户界面布局。在Android …...

第四篇:怎么写express的路由(接口+请求)

🎬 江城开朗的豌豆:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 📝 个人网站 :《 江城开朗的豌豆🫛 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 📘 引言: &#x1f4…...

算法学习记录:有关树的基础

前言: 算法学习记录不是算法介绍,本文记录的是从零开始的学习过程(见到的例题,代码的理解……),所有内容按学习顺序更新,而且不保证正确,如有错误,请帮助指出。 学习工具…...

2. 《大数据之路:阿里巴巴大数据实践》学习笔记,持续更新ing

笔记链接(飞书):https://t0s016els2a.feishu.cn/docx/JrNydGljUonH1ExcGCpcoC8unTb 密码:r661391 该书籍部分目录如下: 文章目录 第1篇 数据技术篇第2章 日志采集2.1 浏览器的页面日志采集2.1.1 页面浏览日志采集流程2.1.2 页面交互日志采集…...

编程笔记 html5cssjs 062 JavaScrip如何使用

编程笔记 html5&css&js 062 JavaScrip如何使用 一、 引入JavaScript二、DOM操作三、事件处理四、数据验证五、异步编程六、使用库和框架七、模块化开发小结 开始学习使用JavaScript进行前端开发的基本步骤和常见实践。 这里先列示基本的步骤和内容,后面慢慢…...

【前端基础--7】

DOM操作 DOM&#xff0c;全称(Document Object Model)&#xff0c;文档对象模型。 提供操作HTML的方法&#xff08;操作页面元素&#xff09; 获取节点 --- 操作元素标签 <body><div id"box">我是盒子标签</div><p class"text"&g…...

微信小程序如何搜索iBeacon设备

1.首先在utils文件夹下创建bluetooth.js和ibeacon.js 2.在 bluetooth.js文件中写入 module.exports {initBluetooth: function () {// 初始化蓝牙模块wx.openBluetoothAdapter({success: function (res) {console.log(蓝牙模块初始化成功);},fail: function (res) {console.l…...

mongodb源码分析session执行handleRequest命令find过程

mongo/transport/service_state_machine.cpp已经分析startSession创建ASIOSession过程&#xff0c;并且验证connection是否超过限制ASIOSession和connection是循环接受客户端命令&#xff0c;把数据流转换成Message&#xff0c;状态转变流程是&#xff1a;State::Created 》 St…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件

在选煤厂、化工厂、钢铁厂等过程生产型企业&#xff0c;其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进&#xff0c;需提前预防假检、错检、漏检&#xff0c;推动智慧生产运维系统数据的流动和现场赋能应用。同时&#xff0c;…...

django filter 统计数量 按属性去重

在Django中&#xff0c;如果你想要根据某个属性对查询集进行去重并统计数量&#xff0c;你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求&#xff1a; 方法1&#xff1a;使用annotate()和Count 假设你有一个模型Item&#xff0c;并且你想…...

土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等

&#x1f50d; 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术&#xff0c;可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势&#xff0c;还能有效评价重大生态工程…...

【HTML-16】深入理解HTML中的块元素与行内元素

HTML元素根据其显示特性可以分为两大类&#xff1a;块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...

IT供电系统绝缘监测及故障定位解决方案

随着新能源的快速发展&#xff0c;光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域&#xff0c;IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选&#xff0c;但在长期运行中&#xff0c;例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...

大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计

随着大语言模型&#xff08;LLM&#xff09;参数规模的增长&#xff0c;推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长&#xff0c;而KV缓存的内存消耗可能高达数十GB&#xff08;例如Llama2-7B处理100K token时需50GB内存&a…...

20个超级好用的 CSS 动画库

分享 20 个最佳 CSS 动画库。 它们中的大多数将生成纯 CSS 代码&#xff0c;而不需要任何外部库。 1.Animate.css 一个开箱即用型的跨浏览器动画库&#xff0c;可供你在项目中使用。 2.Magic Animations CSS3 一组简单的动画&#xff0c;可以包含在你的网页或应用项目中。 3.An…...

为什么要创建 Vue 实例

核心原因:Vue 需要一个「控制中心」来驱动整个应用 你可以把 Vue 实例想象成你应用的**「大脑」或「引擎」。它负责协调模板、数据、逻辑和行为,将它们变成一个活的、可交互的应用**。没有这个实例,你的代码只是一堆静态的 HTML、JavaScript 变量和函数,无法「活」起来。 …...

消息队列系统设计与实践全解析

文章目录 &#x1f680; 消息队列系统设计与实践全解析&#x1f50d; 一、消息队列选型1.1 业务场景匹配矩阵1.2 吞吐量/延迟/可靠性权衡&#x1f4a1; 权衡决策框架 1.3 运维复杂度评估&#x1f527; 运维成本降低策略 &#x1f3d7;️ 二、典型架构设计2.1 分布式事务最终一致…...