线程安全知识点

线程数个数的配置,或者说线程池参数的配置是什么?合理的进行
首先需要确认任务的特性?
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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

張義帥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值