代码之家  ›  专栏  ›  技术社区  ›  Jason

为什么Netty使用“多生产者单消费者”队列?

  •  0
  • Jason  · 技术社区  · 6 年前

    enter image description here

    每个EventLoop(线程)都拥有自己的taskQueue,此队列仅由此EventLoop(线程)操作。那么EventLoop的taskQueue是如何由“多个生产者”操作的呢?

    1 回复  |  直到 6 年前
        1
  •  1
  •   Norman Maurer    6 年前

    EventLoop . 例如,如果你打电话 Channel.write(...) 它将从另一个线程被分派到 用于处理。这意味着需要将其放入 Queue ,这要求它至少是MPSC。