I did quite a bit of research, but I can not find the solution yet. I would like to find a pollable ring buffer
, similar to the LMAX disruptor
one. I have many publishers and one reader.
The problem with disrupto
r is that it uses its own dedicated thread (pool) to read messages, but i would like to read them from the separate thread, which does other things as well.
One alternative I see is to use ManyToOneConcurrentArrayQueue
from agrona
or MpscArrayQueue
from jctools
. But neither of these queues preallocates
objects in the way LMAX disruptor
does. When I call ManyToOneConcurrentArrayQueue::offer
or MpscArrayQueue::offer
I transfer ownership of the object to the queue, and when I call ManyToOneConcurrentArrayQueue::poll
or MpscArrayQueue::poll
I take the ownership from them. It is a problem, since it forces me to have a separate object pool for recycling these objects to avoid garbage creation. It is obviously slower than to have preallocated array
which always keeps an ownership of its contents (a la RingBuffer in LMAX disruptor package).
I wouldn't like to reinvent the wheel and build such a data structure myself, but I couldn't find an existing one either. I will appreciate any help if anybody came across such a structure already.
The disruptor library includes an EventPoller class