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

南充建网站的资料如何免费做网站推广的

南充建网站的资料,如何免费做网站推广的,苏州专业的网站建设公司,1网站建设公司线程池是Java多线程编程中的核心组件,用于管理线程的生命周期、复用线程资源,避免频繁创建和销毁线程带来的性能开销。在高并发场景(如Web服务器、微服务调用等)中,合理使用线程池能显著提升系统性能和稳定性。 1. 为什…

线程池是Java多线程编程中的核心组件,用于管理线程的生命周期、复用线程资源,避免频繁创建和销毁线程带来的性能开销。在高并发场景(如Web服务器、微服务调用等)中,合理使用线程池能显著提升系统性能和稳定性。


1. 为什么需要线程池?

  • 问题:直接创建线程(new Thread())的缺点:

    • 线程创建和销毁开销大(涉及操作系统资源分配)。

    • 无限制创建线程会导致资源耗尽(如内存溢出)。

  • 解决方案:线程池通过复用线程限制并发数任务队列机制解决这些问题。


2. Java中的线程池实现

Java通过java.util.concurrent.ExecutorService接口及其实现类提供线程池支持,核心实现类是ThreadPoolExecutor

2.1 线程池的创建(ThreadPoolExecutor)

ThreadPoolExecutor executor = new ThreadPoolExecutor(int corePoolSize,      // 核心线程数(长期存活的线程)int maximumPoolSize,   // 最大线程数(临时线程 = maximumPoolSize - corePoolSize)long keepAliveTime,    // 临时线程空闲存活时间TimeUnit unit,         // 时间单位(秒/毫秒等)BlockingQueue<Runnable> workQueue, // 任务队列RejectedExecutionHandler handler  // 拒绝策略
);
关键参数说明
参数作用
corePoolSize核心线程数,即使空闲也不会被销毁(除非allowCoreThreadTimeOut=true)。
maximumPoolSize线程池最大能容纳的线程数(核心线程 + 临时线程)。
keepAliveTime临时线程空闲时的存活时间,超时后销毁。
workQueue任务队列,用于存放待执行的任务(常见队列类型见下文)。
handler当线程池和队列都满时,如何处理新任务(拒绝策略)。

2.2 任务队列(BlockingQueue)类型

队列类型特性
ArrayBlockingQueue有界队列,固定大小,任务超出队列大小时会创建临时线程。
LinkedBlockingQueue无界队列(默认Integer.MAX_VALUE),可能导致OOM。
SynchronousQueue不存储任务,直接交给线程执行(需搭配maximumPoolSize使用)。
PriorityBlockingQueue带优先级的无界队列(任务需实现Comparable)。

2.3 拒绝策略(RejectedExecutionHandler)

当线程池和队列都满时,对新任务的处理方式:

策略名行为
AbortPolicy(默认)直接抛出RejectedExecutionException
CallerRunsPolicy让提交任务的线程自己执行该任务(同步执行)。
DiscardPolicy静默丢弃任务,不抛异常。
DiscardOldestPolicy丢弃队列中最旧的任务,然后重新尝试提交当前任务。

3. 线程池的工作流程

  1. 提交任务:调用executor.execute(Runnable task)submit(Callable task)

  2. 线程分配

    • 如果当前线程数 < corePoolSize,立即创建新线程执行任务。

    • 如果线程数 ≥ corePoolSize,任务进入workQueue等待。

    • 如果队列已满且线程数 < maximumPoolSize,创建临时线程执行任务。

    • 如果队列和线程池均满,触发拒绝策略

  3. 线程回收

    • 核心线程默认长期存活。

    • 临时线程在空闲keepAliveTime后被销毁。


4. 常见的线程池工具类(Executors)

Java提供了Executors工具类快速创建线程池(但需注意潜在问题):

方法名底层实现问题
newFixedThreadPool(int n)固定大小的线程池(核心=最大线程数,无界队列)无界队列可能导致OOM。
newCachedThreadPool()可扩容线程池(核心=0,最大=Integer.MAX_VALUE)线程数无限制,可能创建过多线程导致资源耗尽。
newSingleThreadExecutor()单线程池(核心=最大=1,无界队列)无界队列可能导致OOM。
newScheduledThreadPool()支持定时/周期性任务的线程池。无界队列可能导致OOM。

建议:生产环境推荐手动创建ThreadPoolExecutor,避免使用Executors的无界队列。


5. 线程池的最佳实践

  1. 合理配置参数

    • CPU密集型任务:corePoolSize = CPU核心数 + 1

    • IO密集型任务:corePoolSize = 2 * CPU核心数

  2. 避免无界队列:使用ArrayBlockingQueue或自定义有界队列。

  3. 明确拒绝策略:根据业务选择AbortPolicy(日志记录 + 告警)或CallerRunsPolicy

  4. 监控线程池:通过ThreadPoolExecutor的方法(如getActiveCount())或Spring Boot Actuator。


6. 示例代码

// 手动创建线程池
ThreadPoolExecutor executor = new ThreadPoolExecutor(2,                              // corePoolSize5,                              // maximumPoolSize60, TimeUnit.SECONDS,           // keepAliveTimenew ArrayBlockingQueue<>(10),   // 有界队列(容量10)new ThreadPoolExecutor.CallerRunsPolicy() // 拒绝策略
);// 提交任务
executor.execute(() -> {System.out.println("Task executed by " + Thread.currentThread().getName());
});// 关闭线程池(平滑关闭)
executor.shutdown();

7. 常见面试题

  1. 线程池的底层原理是什么?

  2. corePoolSizemaximumPoolSize如何协作?

  3. 无界队列会导致什么问题?

  4. 如何优化线程池参数?

  5. 线程池的拒绝策略有哪些?如何选择?


掌握线程池是Java高并发编程的基础,也是面试高频考点。建议结合源码(如ThreadPoolExecutor)和实际场景(如Web服务器请求处理)加深理解。

http://www.wangmingla.cn/news/30999.html

相关文章:

  • 网站做成app怎么下载app到手机上
  • 口碑好的免费网站建设影视站seo教程
  • 招聘wordpress网站高手兼职百度网站首页
  • 湖南营销型网站建设 j磐石网络seo优质友链购买
  • 大朗做网站公司百度平台推广
  • 找人做网站注意事项杭州seo网站哪家好
  • 做网站需要企业爱站关键词挖掘工具
  • 网页网站怎么做的吗搜狗登录入口
  • 擦边球网站怎么做百度网盘官方网站
  • 电商建站系统学历提升哪个教育机构好一些
  • 国内h5网站欣赏域名注册腾讯云
  • wordpress 维修主题关键词的分类和优化
  • 做英德红茶的网站站长工具浪潮
  • 网站建设服务条款网络优化工程师为什么都说坑人
  • 做网站 注意推广一款app的营销方案
  • 做百度推广是网站好还是阿里好google推广一年的费用
  • 北京空间信息传输中心朝阳seo排名
  • 建设银行网站登录首页线上营销推广方案有哪些
  • 图案生成器为什么seo工资不高
  • 从用户旅程角度做网站分析网络营销专业学什么课程
  • 计算机外包公司有哪些成都seo专家
  • 网站底部备案号代码网站交易网
  • 新都有没有做网站的网络舆情信息
  • 无法定位wordpress内容目录(wp-content)唐山seo推广公司
  • 科技公司 网站 石家庄山东网络推广网站
  • 做防水怎么注册网站网络推广的渠道
  • 网站广告弹窗代码广州网站优化公司
  • 设计服务网站优化百度seo技术搜索引擎
  • 企业网站网络营销案例分析推广app赚钱项目
  • 设计网站实现PDF在线阅读需要怎么做百度统计流量研究院