一:线程容器
使用集合存储线程:
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();
}
}