LinkedBlockingQueue官方文档有这样的介绍:
Linked queues typically have higher throughput than array-based queues but less predictable performance in most concurrent applications.
在大多数并发应用中,链表队列一般比基于数组的队列有更高的吞吐率但是可预测性差。
有点违背我的直觉。
链表队列在插入新数据的时候,需要临时分配堆内存,应该要慢才对,可为什么反而要比预先分配好空间的数组队列性能高呢?
Google了一下 ,发现了别人的测试,竟然和官方文档相反。最后一条评论对我有点启发。
应该比较1读1写 ,而后再测试多读多写, 如果超过8读8写意义就更加不大了,估计你的机器是不会配备如此多的cpu可以同时执行那么多线程,从而造成线程切换时间的开销远大于本身队列的性能
先思考了一下&#x