线程数个数的配置,或者说线程池参数的配置是什么?合理的进行
首先需要确认任务的特性?
cpu密集型:机器cpu核心数+1
io密集型:(磁盘,网络)机器cpu核心数*2
为什么这么设置呢,大量的经验,比如netty就是这么设置的
混合型:(cpu密集,io密集)
如果它们两个相差不大的话(执行时间),尽量拆分,两个线程池
ScheduleThreadPoolExecutor 延时线程池的使用
它的提交有schedule,只执行一次
scheduleWithFixDelay,延迟执行,任务之间的尾到头之间的时间
scheduleAtFixRate ,任务头到头的时间
注意:使用ScheduleThreadPoolExecutor时,内容要用try,catch进行包裹,因为它会吞掉异常
CompletionService,线程谁先执行完,谁先放入队列
线程安全的问题?
线程独有的数据,栈数据,ThreadLocal
类的无状态
一个类没有属性,属性是私有方法,或者用final修饰
安全发布:
含义:一个对象A中包含另一个对象B,B提供了get方法,外界对B进行修改,不影响A中的B对象
集合的话使用jdk自带的Collections
spring,初始化bean的时候,会往一个map中放入bean,怎么保证线程安全的呢?
用的就是Synchronized锁
为什么不用ConcurrentHashMap呢?
bean只初始化一次,只放入一次,考虑性能的方面,用hashMap