线程池的实现

一:线程容器

使用集合存储线程:
ArrayList
HashSet
HashMap
LinkedList

这里使用LinkedList 因为链表的增删快

线程池避免频繁创建线程和销毁线程的资源浪费

二:实现步骤

2.1 当程序启动的时候就创建多个线程,并且把线程保存到链表中,就可以从链表中拿来用

2.2 获取线程
从集合中拿出

2.3 归还线程
把线程放进集合

三:内置线程池

JDK1.5 之后内置线程池

四:线程池的代码实现

4.1 新建线程任务
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

//线程任务
public class MyRunnable implements Runnable{
    private int i = 100;
    Lock l = new ReentrantLock();

    @Override
    public void run() {
        while (true){
            //加锁
            l.lock();
            if (i > 0){
                try {
                    Thread.sleep(10);
                    System.out.println(Thread.currentThread().getName() + " ; " + i--);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally {
                    //最终无论是否异常都释放锁
                    l.unlock();
                }
            }
        }
    }
}

4.2 使用线程池
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ThreadPool {
    public static void main(String[] args) {

        //1.创建线程任务对象
        MyRunnable myRunnable = new MyRunnable();

        //2.创建线程池
        /**
         * Executors 是工厂类
         * newFixedThreadPool() 是静态方法
         * 3 是线程数
         * ExecutorService 是接口
         */
        ExecutorService es = Executors.newFixedThreadPool(2);

        //3.调用 接口 ExecutorService 的submit方法,并且传递线程任务Runnable接口的实现类对象,进行开启线程,执行 run()
        es.submit(myRunnable);
        //使用两个线程执行任务 , 前提做好线程安全同步问题
        //线程池会一直开启,使用完成线程就会重复使用 , ,如果线程池中没有可使用的线程,就会等其他线程被归还后再使用
        es.submit(myRunnable);

        //4.销毁线程池 , 不建议执行
        //es.shutdown();
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值