前言:
最近在开发的时候,在使用多线程的时候,发现了一些问题,不正确的使用,会产生oom的情况,后面看了阿里巴巴的开发手册,亲自验证了一下问题点
,解决了问题,特别mark一下
代码:
package com.ly.tcgl.sellservice.web.controller;
import com.google.common.util.concurrent.ThreadFactoryBuilder;
import org.apache.tomcat.util.threads.ThreadPoolExecutor;
import java.util.concurrent.*;
/**
* @title: 多线程的使用方式,遵守阿里巴巴的规则,否则的话容易产生oom(outofmemory)
* @Author like.ma
* @Date: 2020-09-11 11:16
* @Version 1.0
*/
public class demo {
//错误的创建线程的方式
private static ExecutorService executorService= Executors.newFixedThreadPool(15);
//正确的创建线程的方式
private static ExecutorService executor = new ThreadPoolExecutor(10, 10,
60L, T
多线程的使用,避免ExecutorService 的创建处理
最新推荐文章于 2024-08-05 16:41:16 发布
本文探讨了Java中多线程使用时,如何避免由ExecutorService创建不当引起的内存溢出问题。重点指出不设置ArrayBlockingQueue和LinkedBlockingQueue容量可能导致无界队列,进而造成内存耗尽。推荐通过直接使用ThreadPoolExecutor构造函数并指定队列容量,或者利用guava的ThreadFactoryBuilder创建线程池以避免oom异常。
摘要由CSDN通过智能技术生成