Class CouchbaseQueue<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractQueue<E>
com.couchbase.client.java.datastructures.collections.CouchbaseQueue<E>
- Type Parameters:
E- the type of values in the queue.
- All Implemented Interfaces:
Iterable<E>,Collection<E>,Queue<E>
@Committed @Public public class CouchbaseQueue<E> extends AbstractQueue<E>
A CouchbaseQueue is a
Queue backed by a Couchbase document (more
specifically a JSON array).
Note that as such, a CouchbaseQueue is restricted to the types that a JSON array
can contain. JSON objects and sub-arrays can be represented as JsonObject and JsonArray
respectively. Null values are not allowed as they have special meaning for the peek() and AbstractQueue.remove()
methods of a queue.- Since:
- 2.3.6
- Author:
- Simon Baslé, Subhashni Balakrishnan
-
Constructor Summary
Constructors Constructor Description CouchbaseQueue(String id, Bucket bucket)CouchbaseQueue(String id, Bucket bucket, E... content)CouchbaseQueue(String id, Bucket bucket, Collection<? extends E> content) -
Method Summary
Methods inherited from class java.util.AbstractQueue
add, addAll, element, removeMethods inherited from class java.util.AbstractCollection
contains, containsAll, isEmpty, remove, removeAll, retainAll, toArray, toArray, toStringMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.Collection
contains, containsAll, equals, hashCode, isEmpty, parallelStream, remove, removeAll, removeIf, retainAll, spliterator, stream, toArray, toArray, toArray
-
Constructor Details
-
CouchbaseQueue
Create a newCouchbase-backedQueue, backed by the document identified byidinbucket. Note that if the document already exists, its content will be used as initial content for this collection. Otherwise it is created empty.- Parameters:
id- the id of the Couchbase document to back the queue.bucket- theBucketthrough which to interact with the document.
-
CouchbaseQueue
Create a newCouchbase-backedQueue, backed by the document identified byidinbucket. Note that if the document already exists, its content is reset to the values provided. Note that if you don't provide any value as a vararg, theCouchbaseQueue(String, Bucket)constructor will be invoked instead, which will use pre-existing values as content. To create a new Queue and force it to be empty, useCouchbaseQueue(String, Bucket, Collection)with an empty collection.- Parameters:
id- the id of the Couchbase document to back the queue.bucket- theBucketthrough which to interact with the document.content- vararg of the elements to initially store in the Queue.
-
CouchbaseQueue
Create a newCouchbase-backedQueue, backed by the document identified byidinbucket. Note that if the document already exists, its content is reset to the values provided in thecontentCollection.- Parameters:
id- the id of the Couchbase document to back the queue.bucket- theBucketthrough which to interact with the document.content- collection of the elements to initially store in the Queue, in iteration order.
-
-
Method Details
-
iterator
- Specified by:
iteratorin interfaceCollection<E>- Specified by:
iteratorin interfaceIterable<E>- Specified by:
iteratorin classAbstractCollection<E>
-
size
public int size()- Specified by:
sizein interfaceCollection<E>- Specified by:
sizein classAbstractCollection<E>
-
clear
public void clear()- Specified by:
clearin interfaceCollection<E>- Overrides:
clearin classAbstractQueue<E>
-
offer
-
poll
-
peek
-