java - LMAX Disruptor as a blocking queue? -


is there way can have both in 1 structure -

  1. semantics of blockingqueue, ie - non blocking peek, blocking poll , blocking put. multiple providers 1 consumer.
  2. ringbuffer, works object pool, instead of putting new object in ring buffer, want reuse existing object there, copying state. functionality lmax disruptor has out of box.

is there works already? guess can try , use disruptor that, can use blocking queue blocking put(if ring buffer "full") if understand correctly. has "reusable objects" semantics need. problem how create client able pull objects(instead of using callbacks), i'm not familiar internal disruptor structure - can done? sequencers, creating new eventprocessor or that?

and no, obvious solution of having blocking queue on client side , getting not ideal solution, breaks whole point of using disruptor object pool - you'll need have new pool now, or create new objects in callback before putting in blocking queue etc, , don't want have garbage created @ all.

so there way achieve disruptor, or other performance oriented/garbage free java library?

we open sourced conversant diruptor includes diruptorblockingqueue earlier year. can find code on github

conversant disruptor trivial include in project because supports blockingqueue api , published on maven central.


Comments

Popular posts from this blog

Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.12:test (default-test) on project.Error occurred in starting fork -

windows - Debug iNetMgr.exe unhandle exception System.Management.Automation.CmdletInvocationException -

configurationsection - activeMq-5.13.3 setup configurations for wildfly 10.0.0 -