java.lang.Object
com.carrotsearch.hppc.ByteArrayList
com.carrotsearch.hppc.ByteStack
- All Implemented Interfaces:
Accountable,ByteCollection,ByteContainer,ByteIndexedContainer,Preallocable,Cloneable,Iterable<ByteCursor>,RandomAccess
@Generated(date="2024-06-04T15:20:17+0200",
value="KTypeStack.java")
public class ByteStack
extends ByteArrayList
A subclass of
ByteArrayList adding stack-related utility methods. The top of the stack is
at the ByteArrayList.size() - 1 element.-
Field Summary
Fields inherited from class com.carrotsearch.hppc.ByteArrayList
buffer, elementsCount, EMPTY_ARRAY, resizer -
Constructor Summary
ConstructorsConstructorDescriptionNew instance with sane defaults.ByteStack(int expectedElements) New instance with sane defaults.ByteStack(int expectedElements, ArraySizingStrategy resizer) New instance with sane defaults.ByteStack(ByteContainer container) Create a stack by pushing all elements of another container to it. -
Method Summary
Modifier and TypeMethodDescriptionclone()Clone this object.voiddiscard()Discard the top element from the stack.voiddiscard(int count) Discard an arbitrary number of elements from the top of the stack.static ByteStackfrom(byte... elements) Create a stack by pushing a variable number of arguments to it.bytepeek()Peek at the top element on the stack.bytepop()Remove the top element from the stack and return it.voidpush(byte e1) Adds one byte to the stack.final voidpush(byte... elements) Vararg-signature method for pushing elements at the top of the stack.voidpush(byte[] elements, int start, int len) Add a range of array elements to the stack.voidpush(byte e1, byte e2) Adds two bytes to the stack.voidpush(byte e1, byte e2, byte e3) Adds three bytes to the stack.voidpush(byte e1, byte e2, byte e3, byte e4) Adds four bytes to the stack.intpushAll(ByteContainer container) Pushes all elements from another container to the top of the stack.intpushAll(Iterable<? extends ByteCursor> iterable) Pushes all elements from another iterable to the top of the stack.intDefault implementation uses a predicate for removal.intDefault implementation uses a predicate for retaining.intretainAll(BytePredicate predicate) Default implementation redirects toByteCollection.removeAll(BytePredicate)and negates the predicate.toString()Convert the contents of this container to a human-friendly string.Methods inherited from class com.carrotsearch.hppc.ByteArrayList
add, add, add, add, addAll, addAll, clear, contains, ensureBufferSpace, ensureCapacity, equalElements, equals, forEach, forEach, get, hashCode, indexOf, insert, isEmpty, iterator, lastIndexOf, ramBytesAllocated, ramBytesUsed, release, removeAll, removeAll, removeAt, removeElement, removeFirst, removeLast, removeLast, removeRange, resize, reverse, set, size, sort, toArray, trimToSizeMethods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface com.carrotsearch.hppc.ByteCollection
removeAll, retainAll, retainAllMethods inherited from interface java.lang.Iterable
forEach, spliterator
-
Constructor Details
-
ByteStack
public ByteStack()New instance with sane defaults. -
ByteStack
public ByteStack(int expectedElements) New instance with sane defaults.- Parameters:
expectedElements- The expected number of elements guaranteed not to cause buffer expansion (inclusive).
-
ByteStack
New instance with sane defaults.- Parameters:
expectedElements- The expected number of elements guaranteed not to cause buffer expansion (inclusive).resizer- Underlying buffer sizing strategy.
-
ByteStack
Create a stack by pushing all elements of another container to it.
-
-
Method Details
-
push
public void push(byte e1) Adds one byte to the stack. -
push
public void push(byte e1, byte e2) Adds two bytes to the stack. -
push
public void push(byte e1, byte e2, byte e3) Adds three bytes to the stack. -
push
public void push(byte e1, byte e2, byte e3, byte e4) Adds four bytes to the stack. -
push
public void push(byte[] elements, int start, int len) Add a range of array elements to the stack. -
push
public final void push(byte... elements) Vararg-signature method for pushing elements at the top of the stack.This method is handy, but costly if used in tight loops (anonymous array passing)
-
pushAll
Pushes all elements from another container to the top of the stack. -
pushAll
Pushes all elements from another iterable to the top of the stack. -
discard
public void discard(int count) Discard an arbitrary number of elements from the top of the stack. -
discard
public void discard()Discard the top element from the stack. -
pop
public byte pop()Remove the top element from the stack and return it. -
peek
public byte peek()Peek at the top element on the stack. -
from
Create a stack by pushing a variable number of arguments to it. -
clone
Clone this object. The returned clone will reuse the same hash function and array resizing strategy.- Overrides:
clonein classByteArrayList
-
removeAll
Default implementation uses a predicate for removal.- Specified by:
removeAllin interfaceByteCollection- Returns:
- Returns the number of removed elements.
-
retainAll
Default implementation uses a predicate for retaining.- Specified by:
retainAllin interfaceByteCollection- Returns:
- Returns the number of removed elements.
-
retainAll
Default implementation redirects toByteCollection.removeAll(BytePredicate)and negates the predicate.- Specified by:
retainAllin interfaceByteCollection- Returns:
- Returns the number of removed elements.
-
toString
Convert the contents of this container to a human-friendly string.
-