Class BaseUniversalInmemQueue<T extends BaseUniversalQueueMessage<ID>,ID>
- java.lang.Object
-
- com.github.ddth.queue.impl.AbstractQueue<ID,DATA>
-
- com.github.ddth.queue.impl.AbstractEphemeralSupportQueue<ID,DATA>
-
- com.github.ddth.queue.impl.AbstractInmemEphemeralQueue<ID,DATA>
-
- com.github.ddth.queue.impl.InmemQueue<ID,byte[]>
-
- com.github.ddth.queue.impl.universal.BaseUniversalInmemQueue<T,ID>
-
- Type Parameters:
T-
- All Implemented Interfaces:
IQueue<ID,byte[]>,AutoCloseable
- Direct Known Subclasses:
UniversalInmemQueue,UniversalInmemQueue
public class BaseUniversalInmemQueue<T extends BaseUniversalQueueMessage<ID>,ID> extends InmemQueue<ID,byte[]>
Base class for universal in-memory queue implementations.- Since:
- 0.4.0
- Author:
- Thanh Nguyen
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class com.github.ddth.queue.impl.AbstractQueue
AbstractQueue.PutToQueueCase
-
-
Field Summary
-
Fields inherited from interface com.github.ddth.queue.IQueue
SIZE_NOT_SUPPORTED
-
-
Constructor Summary
Constructors Constructor Description BaseUniversalInmemQueue()BaseUniversalInmemQueue(int boundary)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Ttake()Take a message out of queue.-
Methods inherited from class com.github.ddth.queue.impl.InmemQueue
createQueue, doPutToQueue, finish, getBoundary, init, queueSize, setBoundary, takeFromQueue
-
Methods inherited from class com.github.ddth.queue.impl.AbstractInmemEphemeralQueue
doPutToEphemeralStorage, doRemoveFromEphemeralStorage, ensureEphemeralSize, ephemeralSize, getOrphanMessages, initEphemeralStorage, setEphemeralDisabled
-
Methods inherited from class com.github.ddth.queue.impl.AbstractEphemeralSupportQueue
getEphemeralDisabled, getEphemeralMaxSize, isEphemeralDisabled, setEphemeralMaxSize
-
Methods inherited from class com.github.ddth.queue.impl.AbstractQueue
close, createMessage, createMessage, createMessage, deserialize, deserialize, destroy, getMessageFactory, getQueueName, getSerDeser, queue, requeue, requeueSilent, serialize, setMessageFactory, setQueueName, setSerDeser
-
-
-
-
Method Detail
-
take
public T take()
Take a message out of queue.Implementation flow:
- Read message from head of queue storage.
- Write message to ephemeral storage.
- Remove message from queue storage.
Note: ephemeral storage implementation is optional, depends on implementation.
- Specified by:
takein interfaceIQueue<T extends BaseUniversalQueueMessage<ID>,ID>- Overrides:
takein classInmemQueue<ID,byte[]>- Returns:
-
-