JAVA进阶之路——无奖问答挑战2

JAVA问答第二篇

引言

这里引用b站JAVA韩顺平说过的话鼓励大家

万丈高楼平地起,辉煌还得靠自己

我与大家一起坚持,不要放弃啊!


Q1:为什么要用线程池?

  • 如果不使用线程池,频繁地创建和销毁线程会带来巨大的系统开销。线程池主要解决了以下三个问题:
    降低资源消耗:通过复用已创建的线程,减少了线程创建和销毁所带来的CPU和内存开销。
  • 提高响应速度:任务到达时,无需等待线程创建,直接由池中空闲线程执行,响应极快。
  • 提高可管理性:线程是稀缺资源,无限制创建会导致系统崩溃。线程池可以统一管理线程生命周期,控制最大并发数,甚至进行监控和统计。

Q2:线程池的核心组成部分是啥?

一个标准的线程池通常由以下三部分组成:

  1. 线程池管理器:负责创建、销毁线程池,以及分配任务。
  2. 工作线程(Worker Threads):实际执行任务的线程,执行完任务后不会死亡,而是返回池中等待。
  3. 任务队列(Task Queue):当所有线程都在忙碌时,新来的任务会先被放入这个队列中排队等待。

Q3:讲讲线程池的参数?

参数名 说明
corePoolSize 核心线程数。常驻线程,即使空闲也不会被销毁(除非开启特殊配置)。
maximumPoolSize 最大线程数。线程池能容纳的线程总数上限(核心+临时)。
keepAliveTime 存活时间。非核心线程(临时工)空闲时的存活时间,超时会被回收。
workQueue 工作队列。核心线程满时,任务会进入队列等待。
handler 拒绝策略。队列满且线程数达到最大值时,新任务的处理方式。

Q4: 线程池的工作流程是啥?

当一个新任务提交给线程池时,它会按照以下顺序进行处理:

  1. 优先分配给核心线程:如果当前运行的线程数少于 corePoolSize,线程池会创建新线程来执行任务(即使有空闲线程),直到达到核心线程数。
  2. 尝试入队:如果核心线程都在忙,线程池会尝试将任务放入 workQueue 队列。
  3. 扩容非核心线程:如果队列也满了,且当前线程数小于 maximumPoolSize,线程池会创建"非核心线程"来执行任务。
  4. 触发拒绝策略:如果线程数达到最大值且队列也满,线程池会启动拒绝策略(如抛出异常、丢弃任务、或由调用者线程自己执行等)。

Q5:HTTP与HTTPS的区别?

比较维度 HTTP HTTPS
安全性 低(明文传输,数据裸奔) 高(加密传输,防窃听/篡改)
默认端口 80 端口 443 端口
协议基础 基于 TCP 协议 HTTP + SSL/TLS 加密层
证书要求 不需要证书 需要向 CA 机构申请数字证书
SEO 排名 较低(被搜索引擎降权) 较高(搜索引擎优先收录)
相关推荐
八零后琐话6 小时前
干货:程序员必备性能分析工具——Arthas火焰图
开发语言·python
3GPP仿真实验室6 小时前
【MATLAB源码】CORDIC-QR :基于Cordic硬件级矩阵QR分解
开发语言·matlab·矩阵
知南x6 小时前
【Ascend C系列课程(高级)】(1) 算子调试+调优
c语言·开发语言
忆~遂愿6 小时前
GE 引擎与算子版本控制:确保前向兼容性与图重写策略的稳定性
大数据·开发语言·docker
Ro Jace7 小时前
计算机专业基础教材
java·开发语言
代码游侠7 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
mango_mangojuice7 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
程序员侠客行7 小时前
Mybatis连接池实现及池化模式
java·后端·架构·mybatis
devmoon7 小时前
运行时(Runtime)是什么?为什么 Polkadot 的 Runtime 可以被“像搭积木一样”定制
开发语言·区块链·智能合约·polkadot·runtmie