老实说,对于线程池我还是属于比较初级的阶段。
下面是我自己设计线程池的思想。
1.有一个线程池mananger.
2.有个工作list.
3.有个等待list.
4.有个实现了Runnable的Task.
一般的逻辑很简单,就是当外面有新的线程进来时候,我们就把先check工作list是否已经满了,
如果没满:
就加进去,然后start。
当线程run方法结束后,我们就把它从工作list的去掉。
如果满了,
就进等待list,不执行start.
然后在外面开个线程,不停的Thread.sleep(1000),去隔一秒的检查工作list是否有空,如果有空位,就把等待list的里的一个线程拿出来,放进工作list.
这个整个线程池的结构就搭好了,这里有个关键,就是我们外面放进去的线程怎么能在自己run方法结束后通知Manager,要把自己从工作list里去掉呢?
这时候,我们可以用外面进来的线程去构造一个Task.
让Task 的run去调用外面进来线程的run,让Task 代替外面进来的线程去start.
结构如:
这样就能通知到了。
这个只是我个人的构想。
我们还可以参数tomcat线程池类作研究。
现在tomcat7的线程池是ThreadPoolExecutor,它继承的就是jdk自带的util里ThreadPoolExecutor。
下面是我自己设计线程池的思想。
1.有一个线程池mananger.
2.有个工作list.
3.有个等待list.
4.有个实现了Runnable的Task.
一般的逻辑很简单,就是当外面有新的线程进来时候,我们就把先check工作list是否已经满了,
如果没满:
就加进去,然后start。
当线程run方法结束后,我们就把它从工作list的去掉。
如果满了,
就进等待list,不执行start.
然后在外面开个线程,不停的Thread.sleep(1000),去隔一秒的检查工作list是否有空,如果有空位,就把等待list的里的一个线程拿出来,放进工作list.
这个整个线程池的结构就搭好了,这里有个关键,就是我们外面放进去的线程怎么能在自己run方法结束后通知Manager,要把自己从工作list里去掉呢?
这时候,我们可以用外面进来的线程去构造一个Task.
让Task 的run去调用外面进来线程的run,让Task 代替外面进来的线程去start.
结构如:
Task implements Runnable{
run(){
外面新进来的线程.run();
通知外面进来的线程结束了;
}
}
这样就能通知到了。
这个只是我个人的构想。
我们还可以参数tomcat线程池类作研究。
现在tomcat7的线程池是ThreadPoolExecutor,它继承的就是jdk自带的util里ThreadPoolExecutor。