java多线程创建方式

复制代码
    int corePoolSize = 20;
    int maximumPoolSize = 40;
    long keepAliveTime = 20;
    TimeUnit unit = TimeUnit.SECONDS;
    BlockingQueue<Runnable> workQueue = new ArrayBlockingQueue<>(5000);
    ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, maximumPoolSize, keepAliveTime, unit,
            workQueue);

    protected void process(Date data) {
        executor.execute(new Runnable() {
            @Override
            public void run() {
                try {
                    long start = new Date().getTime();
                    //实际处理的方法
            handle(data);
long end = new Date().getTime(); log.info("data key :" + data.getKey() + ",time:" + (end - start) + "ms" + ",workQueue size" + workQueue.remainingCapacity()); if (workQueue.remainingCapacity() < 500) { log.error("work queue nearly full :data key:" + data.getKey() + ",time:" + (end - start) + "ms" + ",workQueue size" + workQueue.remainingCapacity()); } } catch (Exception e) { log.error("process error", e); } } }); }
复制代码

1. 传入的数据Data,要设置唯一key,在日志中打印key

2.剩余线程数不足时,打印错误日志

3.handle(data)是实际的处理方法。

posted @   然然1907  阅读(42)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示