最近开始学ThreadPoolExecutor,知道里面线程等待也是通过队列实现的,那比如这个队列ArrayBlockingQueue,我看里面实现就是用ReentrantLock实现,而ReentrantLock里面又有AbstractQueuedSynchronizer来实现争抢锁的时候等候排队,那外面都有队列了里面的队列还有用吗?还有为啥ArrayBlockingQueue这个要用数组实现?换链表会不会更快一点
多线程是同时执行的,同步的安全性更高吧。
1.当然有用
2.链表更慢
两个队列就不是一个东东,缓存队列是等待执行的线程任务,AQS里面是线程并发,想要插入缓存队列的线程。
ArrayBlockingQueue 看名字就知道是array实现啊,链表也有实现,是LinkedBlockingQueue,都是阻塞队列LinkedBlockingQueue加了头锁和尾锁,ArrayBlockingQueue只使用了一个锁,具体差别可以自己看源码,这里也写不下
您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y