一、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()是下一个线程。
本文深入解析Java反射机制、Spring IoC容器的Bean管理策略、Java注解体系的应用、线程池的工作原理及其在多线程编程中的高效使用方法。通过详细讲解ExecutorService的创建与使用,以及Callable和FutureTask在实现带返回值的多线程任务中的角色,帮助读者掌握Java并发编程的核心技巧。
348

被折叠的 条评论
为什么被折叠?



