java并发编程/反射/注解学习
一、java反射
二、spring ioc 容器实现bean的几种方式
三、java注解体系
四、java线程池
Exectors 及ExectorService创建和使用上述线程池
结合上述原理可以查看线程池源码
线程池的使用
1,使用Exectors创建一个适合业务的线程池,返回的是ExectorService
2,定义线程方法run的实体
3,使用ExectorService.execte(传入线程池的类),最后线程池执行完,记得exectorService.shutdown();关闭
最终打印的线程池名字就是1,2,3个
带返回值的多线程
或者如下
futureTask其实也是一个线程,只不过他可以通过get()这个阻塞的方法获取线程池返回的值。
callable接口,就一个call方法。
futureTask类关系如下
runnablefuture就一个run方法, future主要是任务的生命周期。
线程池的释放,当超时或者run()方法执行完时,释放部分非核心线程,直到释放的线程数达到核心线程时,暂停释放了。
创建的线程使用set集合存储,线程间使用连表关联,next()是下一个线程。