自己线程池设计的主要结构

老实说,对于线程池我还是属于比较初级的阶段。
下面是我自己设计线程池的思想。

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。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值