Unageek.Collections.Deque
1.0.0
Prefix Reserved
dotnet add package Unageek.Collections.Deque --version 1.0.0
NuGet\Install-Package Unageek.Collections.Deque -Version 1.0.0
<PackageReference Include="Unageek.Collections.Deque" Version="1.0.0" />
<PackageVersion Include="Unageek.Collections.Deque" Version="1.0.0" />
<PackageReference Include="Unageek.Collections.Deque" />
paket add Unageek.Collections.Deque --version 1.0.0
#r "nuget: Unageek.Collections.Deque, 1.0.0"
#:package Unageek.Collections.Deque@1.0.0
#addin nuget:?package=Unageek.Collections.Deque&version=1.0.0
#tool nuget:?package=Unageek.Collections.Deque&version=1.0.0
Deque<T>
Deque<T> is a .NET implementation of double-ended queue.
using Unageek.Collections;
var queue = new Deque<string>();
queue.AddLast("one");
queue.AddLast("two");
queue.AddLast("three");
var stack = new Deque<string>();
stack.AddFirst("three");
stack.AddFirst("two");
stack.AddFirst("one");
Console.WriteLine(queue.SequenceEqual(stack)); // True
Features
Drop-in replacement for
List<T>Deque<T>implements the same interfaces, methods, and properties asList<T>, including random access, bulk insertion/removal, and binary search.Performance
Random insertion and removal are expected to be twice as fast as
List<T>.Additional methods
Deque<T>also provides the following methods:void AddFirst(T item)(equivalent toAdd)void AddLast(T item)void RemoveFirst()void RemoveLast()T PeekFirst()T PeekLast()T PopFirst()T PopLast()bool TryPeekFirst(out T item)bool TryPeekLast(out T item)bool TryPopFirst(out T item)bool TryPopLast(out T item)
Limitations
The maximum number of elements a
Deque<T>can hold is 2<sup>30</sup> = 1,073,741,824. If you try to add more items, anOutOfMemoryExceptionis thrown.The capacity of a
Deque<T>can only be zero or a power of two (up to 2<sup>30</sup>).Serialization is not supported.
Supported .NET Versions
.NET 6+ is supported.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net6.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.0 | 942 | 8/7/2022 |
| 1.0.0-rc.1 | 211 | 8/7/2022 |
| 1.0.0-rc.0 | 221 | 8/5/2022 |