zoukankan      html  css  js  c++  java
  • 线程池

    线程池

    为什么需要线程池

    • 经常创建和销毁线程是耗时且不稳定的,很难胜任并发度较高的任务。
    • 可以采用池化方法解决这个问题,提前创建好多个线程,构成一个线程池,使用时直接获取,使用完放回池中,避免了频繁创建销毁的消耗。

    使用线程池

    • JDK5.0提供了线程池相关的API:ExecutorService和Executors
    • ExecutorService:真正的线程池接口。常见子类ThreadPoolExecutor。
    • Executors:工具类,线程池的工厂类,用于创建并返回不同类型的线程池。

    代码实现

    package MultiProcess;
    
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    
    public class TestPoll {
        public static void main(String[] args) {
            //1.创建服务,创建线程池
            ExecutorService service = Executors.newFixedThreadPool(10);
    
            //2.执行
            service.execute(new MyThread());
            service.execute(new MyThread());
            service.execute(new MyThread());
            service.execute(new MyThread());
            service.execute(new MyThread());
    
            //3.关闭
            service.shutdown();
        }
    }
    
    class MyThread implements Runnable{
        @Override
        public void run() {
    
            System.out.println(Thread.currentThread().getName());
    
        }
    }
    
    结果
    pool-1-thread-1
    pool-1-thread-2
    pool-1-thread-3
    pool-1-thread-4
    pool-1-thread-5
    
  • 相关阅读:
    消息队列介绍
    SpringBoot随笔-SpringBoot集成Druid
    Redis-Redis基本类型及使用Java操作
    信息安全
    计算机网络基础
    多媒体技术
    数据库基础
    程序设计基础
    计算机软件体系
    计算机硬件体系
  • 原文地址:https://www.cnblogs.com/happysml/p/13848685.html
Copyright © 2011-2022 走看看