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 排名 较低(被搜索引擎降权) 较高(搜索引擎优先收录)
相关推荐
二哈赛车手8 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
为何创造硅基生物8 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好8 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
栗子~~8 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
星寂樱易李8 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
YDS8299 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
仰泳之鹅9 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
之歆9 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
未若君雅裁10 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
cen__y10 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git