Struct ArrayDeque

Source
pub struct ArrayDeque<T, const N: usize>
where T: Default,
{ /* private fields */ }
Expand description

A double-ended queue with fixed capacity, backed by an array.

The capacity of the deque is determined by the generic parameter N.

All values are stored inline; that is, the size of of ArrayDeque<T, N> is at least size_of::<[T; N]>(), regardless of the number of elements currently stored in the deque.

Implementations§

Source§

impl<T, const N: usize> ArrayDeque<T, N>
where T: Default,

Source

pub fn new() -> Self

Constructs a new, empty ArrayDeque<T, N>.

§Example
let mut deque: ArrayDeque<String, 8> = ArrayDeque::new();

assert!(deque.is_empty());
Source

pub fn capacity(&self) -> usize

Returns the maximum number of elements the deque may hold.

This has the same value as the const generic parameter N.

§Example
use holodeque::ArrayDeque;
let mut deque: ArrayDeque<(), 42> = ArrayDeque::new();

assert_eq!(deque.capacity(), 42);
Source

pub fn len(&self) -> usize

Returns the number of elements in the deque.

§Example
let mut deque: ArrayDeque<char, 3> = ArrayDeque::new();

deque.push_back('a')?;
deque.push_back('b')?;
deque.push_back('c')?;

assert_eq!(deque.len(), 3);
Source

pub fn is_empty(&self) -> bool

Returns true if the deque contains no elements.

§Example
let mut deque: ArrayDeque<u32, 8> = ArrayDeque::new();

deque.push_back(42)?;
assert!(!deque.is_empty());
deque.pop_front();
assert!(deque.is_empty());
Source

pub fn is_full(&self) -> bool

Returns true if the deque is at capacity.

§Example
let mut deque: ArrayDeque<u32, 4> = ArrayDeque::new();

deque.push_back(1)?;
deque.push_back(2)?;
deque.push_back(3)?;
assert!(!deque.is_full());

deque.push_back(4)?;
assert!(deque.is_full());
Source

pub fn front(&self) -> Option<&T>

Returns a reference to the first element in the deque.

If the deque is empty, None is returned.

§Example
let mut deque: ArrayDeque<char, 3> = ArrayDeque::new();

deque.push_back('a')?;
deque.push_back('b')?;
deque.push_back('c')?;

assert_eq!(deque.front(), Some(&'a'));
Source

pub fn front_mut(&mut self) -> Option<&mut T>

Returns a mutable reference to the first element in the deque.

If the deque is empty, None is returned.

§Example
let mut deque: ArrayDeque<&str, 4> = ArrayDeque::new();

deque.push_front("old")?;
deque.front_mut().map(|mut val| {
    *val = "new";
});

assert_eq!(deque.front(), Some(&"new"));
Source

pub fn back(&self) -> Option<&T>

Returns a reference to the last element in the deque.

If the deque is empty, None is returned.

§Example
let mut deque: ArrayDeque<char, 3> = ArrayDeque::new();

deque.push_back('a')?;
deque.push_back('b')?;
deque.push_back('c')?;

assert_eq!(deque.back(), Some(&'c'));
Source

pub fn back_mut(&mut self) -> Option<&mut T>

Returns a mutable reference to the last element in the deque.

If the deque is empty, None is returned.

§Example
let mut deque: ArrayDeque<&str, 4> = ArrayDeque::new();

deque.push_back("old")?;
deque.back_mut().map(|mut val| {
    *val = "new";
});

assert_eq!(deque.back(), Some(&"new"));
Source

pub fn as_slices(&self) -> (&[T], &[T])

Returns a pair of slices which contain, in order, the elements of the ArrayDeque.

§Example
let mut deque: ArrayDeque<u32, 6> = ArrayDeque::new();

deque.push_front(3)?;
deque.push_front(6)?;
deque.push_front(9)?;
deque.push_back(5)?;
deque.push_back(10)?;
deque.push_back(15)?;

let (first, second) = deque.as_slices();
assert_eq!(first, &[9, 6, 3]);
assert_eq!(second, &[5, 10, 15]);
Source

pub fn as_mut_slices(&mut self) -> (&mut [T], &mut [T])

Returns a pair of mutable slices which contain, in order, the elements of the ArrayDeque.

§Example
let mut deque: ArrayDeque<u32, 6> = ArrayDeque::new();

deque.push_front(3)?;
deque.push_front(6)?;
deque.push_front(9)?;
deque.push_back(5)?;
deque.push_back(10)?;
deque.push_back(15)?;

let (first_mut, second_mut) = deque.as_mut_slices();
for item in first_mut {
    *item -= 1;
}
for item in second_mut {
    *item += 1;
}

let (first, second) = deque.as_slices();
assert_eq!(first, &[8, 5, 2]);
assert_eq!(second, &[6, 11, 16]);
Source

pub fn push_front(&mut self, item: T) -> Result<(), CapacityError<T>>

Prepends an element to the deque.

If the deque is at capacity, an Err containing the pushed value is returned.

§Example
let mut deque: ArrayDeque<u32, 3> = ArrayDeque::new();

deque.push_front(1)?;
deque.push_front(2)?;
deque.push_front(3)?;

assert_eq!(deque.front(), Some(&3));
assert_eq!(deque.back(), Some(&1));

// Another element would exceed capacity, so this fails.
let err = deque.push_front(4).unwrap_err();
assert_eq!(err.into_inner(), 4);
Source

pub fn push_back(&mut self, item: T) -> Result<(), CapacityError<T>>

Appends an element to the deque.

If the deque is at capacity, an Err containing the pushed value is returned.

§Example
let mut deque: ArrayDeque<u32, 3> = ArrayDeque::new();

deque.push_back(1)?;
deque.push_back(2)?;
deque.push_back(3)?;

assert_eq!(deque.front(), Some(&1));
assert_eq!(deque.back(), Some(&3));

// Another element would exceed capacity, so this fails.
let err = deque.push_front(4).unwrap_err();
assert_eq!(err.into_inner(), 4);
Source

pub fn pop_front(&mut self) -> Option<T>

Removes and returns the first element of the deque.

If the deque is empty, None is returned.

§Example
let mut deque: ArrayDeque<u32, 3> = ArrayDeque::new();

deque.push_back(1)?;
deque.push_back(2)?;
deque.push_back(3)?;

assert_eq!(deque.pop_front(), Some(1));
assert_eq!(deque.pop_front(), Some(2));
assert_eq!(deque.pop_front(), Some(3));
assert_eq!(deque.pop_front(), None);
Source

pub fn pop_back(&mut self) -> Option<T>

Removes and returns the last element of the deque.

If the deque is empty, None is returned.

§Example
let mut deque: ArrayDeque<u32, 3> = ArrayDeque::new();

deque.push_back(1)?;
deque.push_back(2)?;
deque.push_back(3)?;

assert_eq!(deque.pop_back(), Some(3));
assert_eq!(deque.pop_back(), Some(2));
assert_eq!(deque.pop_back(), Some(1));
assert_eq!(deque.pop_back(), None);
Source

pub fn clear(&mut self)

Clears the ArrayDeque, removing all values.

§Example
let mut deque: ArrayDeque<usize, 8> = ArrayDeque::new();

for i in 0..deque.capacity() / 2 {
    deque.push_front(i)?;
    deque.push_back(i)?;
}

assert_eq!(deque.len(), 8);
deque.clear();
assert!(deque.is_empty());
Source

pub fn truncate(&mut self, len: usize)

Shortens the ArrayDeque, keeping the first len elements and dropping the rest.

If len is greater than the ArrayDeque’s current length, this has no effect.

§Example
let mut deque: ArrayDeque<usize, 8> = ArrayDeque::new();

deque.push_back(5)?;
deque.push_back(10)?;
deque.push_back(15)?;
deque.push_back(20)?;
deque.push_back(25)?;

assert_eq!(deque.len(), 5);
deque.truncate(2);
assert_eq!(deque.len(), 2);
Source

pub fn iter(&self) -> Iter<'_, T, N>

Returns an iterator over the elements of the deque.

§Example
let mut deque: ArrayDeque<&str, 5> = ArrayDeque::new();

deque.push_back("ideas")?;
deque.push_front("green")?;
deque.push_back("sleep")?;
deque.push_front("colorless")?;
deque.push_back("furiously")?;

let sentence = deque.iter().cloned().collect::<Vec<_>>();

assert_eq!(
    sentence,
    &["colorless", "green", "ideas", "sleep", "furiously"],
);
Source

pub fn drain_front(&mut self, n: usize) -> Option<DrainFront<'_, T, N>>

Drains n elements from the front of the deque.

If n exceeds self.len(), None is returned.

When this method is called, n elements are immediately removed from the front of the deque. If the returned iterator is dropped before yielding all its items, they are dropped along with it.

If the returned iterator is leaked (e.g. with mem::forget), the drained elements will not be dropped immediately. They may be dropped as a result of subsequent operations on the deque; otherwise, they will be dropped when the deque itself is dropped.

§Example
let mut deque: ArrayDeque<u32, 5> = ArrayDeque::new();

deque.push_back(0)?;
deque.push_back(1)?;
deque.push_back(2)?;
deque.push_back(3)?;
deque.push_back(4)?;

let mut drain = deque.drain_front(3).unwrap();

assert_eq!(drain.next(), Some(0));
assert_eq!(drain.next(), Some(1));
assert_eq!(drain.next(), Some(2));
assert_eq!(drain.next(), None);
drop(drain);

assert_eq!(deque.len(), 2);
Source

pub fn drain_back(&mut self, n: usize) -> Option<DrainBack<'_, T, N>>

Drains n elements from the back of the deque.

If n exceeds self.len(), None is returned.

When this method is called, n elements are immediately removed from the back of the deque. If the returned iterator is dropped before yielding all its items, they are dropped along with it.

If the returned iterator is leaked (e.g. with mem::forget), the drained elements will not be dropped immediately. They may be dropped as a result of subsequent operations on the deque; otherwise, they will be dropped when the deque itself is dropped.

§Example
let mut deque: ArrayDeque<u32, 5> = ArrayDeque::new();

deque.push_back(0)?;
deque.push_back(1)?;
deque.push_back(2)?;
deque.push_back(3)?;
deque.push_back(4)?;

let mut drain = deque.drain_back(3).unwrap();

assert_eq!(drain.next(), Some(4));
assert_eq!(drain.next(), Some(3));
assert_eq!(drain.next(), Some(2));
assert_eq!(drain.next(), None);
drop(drain);

assert_eq!(deque.len(), 2);

Trait Implementations§

Source§

impl<T, const N: usize> Clone for ArrayDeque<T, N>
where T: Default + Clone,

Source§

fn clone(&self) -> ArrayDeque<T, N>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T, const N: usize> Debug for ArrayDeque<T, N>
where T: Default + Debug,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T, const N: usize> Default for ArrayDeque<T, N>
where T: Default,

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<'de, T, const N: usize> Deserialize<'de> for ArrayDeque<T, N>
where T: Deserialize<'de> + Default,

Source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl<T, const N: usize> PartialEq for ArrayDeque<T, N>
where T: PartialEq + Default,

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T, const N: usize> Serialize for ArrayDeque<T, N>
where T: Serialize + Default,

Source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl<T, const N: usize> Eq for ArrayDeque<T, N>
where T: PartialEq + Default,

Auto Trait Implementations§

§

impl<T, const N: usize> Freeze for ArrayDeque<T, N>
where T: Freeze,

§

impl<T, const N: usize> RefUnwindSafe for ArrayDeque<T, N>
where T: RefUnwindSafe,

§

impl<T, const N: usize> Send for ArrayDeque<T, N>
where T: Send,

§

impl<T, const N: usize> Sync for ArrayDeque<T, N>
where T: Sync,

§

impl<T, const N: usize> Unpin for ArrayDeque<T, N>
where T: Unpin,

§

impl<T, const N: usize> UnwindSafe for ArrayDeque<T, N>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,