java并发编程/反射/注解学习

一、java反射

java并发编程/反射/注解学习

二、spring ioc 容器实现bean的几种方式

java并发编程/反射/注解学习

 

java并发编程/反射/注解学习

 

三、java注解体系

java并发编程/反射/注解学习

java并发编程/反射/注解学习

 

四、java线程池

java并发编程/反射/注解学习

java并发编程/反射/注解学习

java并发编程/反射/注解学习

Exectors 及ExectorService创建和使用上述线程池

java并发编程/反射/注解学习

java并发编程/反射/注解学习

结合上述原理可以查看线程池源码

线程池的使用

java并发编程/反射/注解学习

1,使用Exectors创建一个适合业务的线程池,返回的是ExectorService

2,定义线程方法run的实体

3,使用ExectorService.execte(传入线程池的类),最后线程池执行完,记得exectorService.shutdown();关闭

最终打印的线程池名字就是1,2,3个

 

带返回值的多线程

java并发编程/反射/注解学习

或者如下

java并发编程/反射/注解学习

futureTask其实也是一个线程,只不过他可以通过get()这个阻塞的方法获取线程池返回的值。

callable接口,就一个call方法。

futureTask类关系如下

java并发编程/反射/注解学习

runnablefuture就一个run方法, future主要是任务的生命周期。

线程池的释放,当超时或者run()方法执行完时,释放部分非核心线程,直到释放的线程数达到核心线程时,暂停释放了。

创建的线程使用set集合存储,线程间使用连表关联,next()是下一个线程。