Ecng.Collections
1.0.285
dotnet add package Ecng.Collections --version 1.0.285
NuGet\Install-Package Ecng.Collections -Version 1.0.285
<PackageReference Include="Ecng.Collections" Version="1.0.285" />
<PackageVersion Include="Ecng.Collections" Version="1.0.285" />
<PackageReference Include="Ecng.Collections" />
paket add Ecng.Collections --version 1.0.285
#r "nuget: Ecng.Collections, 1.0.285"
#:package Ecng.Collections@1.0.285
#addin nuget:?package=Ecng.Collections&version=1.0.285
#tool nuget:?package=Ecng.Collections&version=1.0.285
Ecng.Collections
Thread-safe collections, specialized data structures, and collection utilities for high-performance scenarios.
Thread-Safe Collections
All synchronized collections provide thread-safe operations with internal locking.
SynchronizedDictionary
Thread-safe wrapper around Dictionary<TKey, TValue>.
var dict = new SynchronizedDictionary<int, string>();
// Thread-safe operations
dict[1] = "one";
dict.Add(2, "two");
if (dict.TryGetValue(1, out var value))
Console.WriteLine(value); // "one"
// Manual locking for compound operations
using (dict.EnterScope())
{
if (!dict.ContainsKey(3))
dict.Add(3, "three");
}
SynchronizedList
Thread-safe list with notification support.
var list = new SynchronizedList<string>();
list.Add("item1");
list.AddRange(new[] { "item2", "item3" });
// Safe iteration with scope
using (list.EnterScope())
{
foreach (var item in list)
Console.WriteLine(item);
}
CachedSynchronizedList
Thread-safe list that caches its array representation for fast enumeration.
var list = new CachedSynchronizedList<int>();
list.Add(1);
list.Add(2);
list.Add(3);
// Cache is computed once and reused until list changes
int[] cached = list.Cache;
foreach (var item in cached)
Console.WriteLine(item);
// After modification, cache is invalidated
list.Add(4);
int[] newCache = list.Cache; // Recomputed
CachedSynchronizedDictionary
Thread-safe dictionary with cached key/value arrays.
var dict = new CachedSynchronizedDictionary<string, int>();
dict["a"] = 1;
dict["b"] = 2;
// Cached arrays for fast iteration
string[] keys = dict.CachedKeys;
int[] values = dict.CachedValues;
KeyValuePair<string, int>[] pairs = dict.CachedPairs;
SynchronizedSet
Thread-safe HashSet<T> wrapper.
var set = new SynchronizedSet<int>();
set.Add(1);
set.Add(2);
bool added = set.Add(1); // false, already exists
bool contains = set.Contains(1); // true
Specialized Collections
PairSet - Bidirectional Dictionary
Allows lookup by both key and value.
var pairs = new PairSet<int, string>();
pairs.Add(1, "one");
pairs.Add(2, "two");
// Forward lookup (key -> value)
string value = pairs.GetValue(1); // "one"
// Reverse lookup (value -> key)
int key = pairs.GetKey("two"); // 2
// Check existence
bool hasKey = pairs.ContainsKey(1);
bool hasValue = pairs.ContainsValue("one");
// Remove by value
pairs.RemoveByValue("one");
SynchronizedPairSet
Thread-safe version of PairSet.
var pairs = new SynchronizedPairSet<Guid, string>();
var id = Guid.NewGuid();
pairs.Add(id, "session-1");
// Thread-safe bidirectional lookup
if (pairs.TryGetValue(id, out var session))
Console.WriteLine(session);
if (pairs.TryGetKey("session-1", out var foundId))
Console.WriteLine(foundId);
CircularBuffer
Fixed-size buffer that overwrites oldest elements when full.
var buffer = new CircularBuffer<int>(capacity: 3);
buffer.PushBack(1);
buffer.PushBack(2);
buffer.PushBack(3);
// Buffer: [1, 2, 3]
buffer.PushBack(4);
// Buffer: [2, 3, 4] - oldest (1) was overwritten
int front = buffer.Front(); // 2
int back = buffer.Back(); // 4
int second = buffer[1]; // 3
// Remove from ends
buffer.PopFront(); // Removes 2
buffer.PopBack(); // Removes 4
// Convert to array
int[] arr = buffer.ToArray();
// Resize buffer
buffer.Capacity = 5; // Grow
buffer.Capacity = 2; // Shrink (keeps newest elements)
CircularBufferEx
Extended circular buffer with additional operations.
var buffer = new CircularBufferEx<decimal>(100);
// Add elements
buffer.PushBack(1.5m);
buffer.PushBack(2.5m);
// Sum, min, max operations
decimal sum = buffer.Sum;
decimal min = buffer.Min;
decimal max = buffer.Max;
NumericCircularBufferEx
Circular buffer optimized for numeric calculations with running statistics.
var buffer = new NumericCircularBufferEx<double>(100);
for (int i = 0; i < 100; i++)
buffer.PushBack(Math.Sin(i));
// Efficient statistics (computed incrementally)
double sum = buffer.Sum;
double min = buffer.Min;
double max = buffer.Max;
Queue and Stack Extensions
SynchronizedQueue
Thread-safe queue.
var queue = new SynchronizedQueue<Message>();
queue.Enqueue(new Message("hello"));
if (queue.TryDequeue(out var msg))
Process(msg);
SynchronizedStack
Thread-safe stack.
var stack = new SynchronizedStack<int>();
stack.Push(1);
stack.Push(2);
if (stack.TryPop(out var value))
Console.WriteLine(value); // 2
QueueEx / StackEx
Extended queue and stack with additional peek operations.
var queue = new QueueEx<int>();
queue.Enqueue(1);
queue.Enqueue(2);
queue.Enqueue(3);
int first = queue.PeekFirst(); // 1 (front)
int last = queue.PeekLast(); // 3 (back)
Ordered Channels
BaseOrderedChannel
Base class for ordered message processing with channels.
// Used for ordered async message processing
// See ChannelExtensions for usage patterns
Bit Array Operations
BitArrayWriter / BitArrayReader
Efficient bit-level I/O for binary data.
// Writing bits
var writer = new BitArrayWriter();
writer.Write(true); // 1 bit
writer.Write(42, 8); // 8 bits
writer.WriteInt(1000); // Variable-length int
byte[] data = writer.ToArray();
// Reading bits
var reader = new BitArrayReader(data);
bool flag = reader.Read(); // 1 bit
int value = reader.Read(8); // 8 bits
int number = reader.ReadInt(); // Variable-length int
Collection Interfaces
INotifyList
List that raises events on modifications.
public interface INotifyList<T> : IList<T>
{
event Action<T> Adding;
event Action<T> Added;
event Action<T> Removing;
event Action<T> Removed;
event Action Clearing;
event Action Cleared;
event Action Changed;
}
ISynchronizedCollection
Interface for thread-safe collections.
public interface ISynchronizedCollection<T> : ICollection<T>
{
Lock SyncRoot { get; }
LockScope EnterScope();
}
Extension Methods
using Ecng.Collections;
// Check if collection is empty
IEnumerable<int> items = GetItems();
if (items.IsEmpty())
return;
// Safe first/last
var first = items.FirstOr(defaultValue: -1);
var last = items.LastOr(defaultValue: -1);
// Batch processing
foreach (var batch in items.Batch(100))
ProcessBatch(batch);
// Index lookup
int index = items.IndexOf(x => x > 10);
NuGet
Install-Package Ecng.Collections
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. 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 is compatible. 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. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Ecng.Common (>= 1.0.250)
- System.Threading.Channels (>= 8.0.0)
-
net10.0
- Ecng.Common (>= 1.0.250)
-
net6.0
- Ecng.Common (>= 1.0.250)
NuGet packages (8)
Showing the top 5 NuGet packages that depend on Ecng.Collections:
| Package | Downloads |
|---|---|
|
Ecng.Reflection
Ecng system framework |
|
|
Ecng.Security
Ecng system framework |
|
|
Ecng.StringSearch
Ecng system framework |
|
|
Ecng.Roslyn
Ecng system framework |
|
|
Ecng.Backup.Mega
Ecng system framework |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.285 | 2,232 | 2/4/2026 |
| 1.0.284 | 2,061 | 2/1/2026 |
| 1.0.283 | 1,677 | 1/26/2026 |
| 1.0.282 | 867 | 1/22/2026 |
| 1.0.281 | 2,112 | 1/19/2026 |
| 1.0.280 | 838 | 1/19/2026 |
| 1.0.279 | 815 | 1/18/2026 |
| 1.0.278 | 807 | 1/18/2026 |
| 1.0.277 | 1,453 | 1/14/2026 |
| 1.0.276 | 1,055 | 1/13/2026 |
| 1.0.275 | 1,379 | 1/13/2026 |
| 1.0.274 | 9,224 | 1/9/2026 |
| 1.0.273 | 10,400 | 1/9/2026 |
| 1.0.272 | 40,585 | 1/4/2026 |
| 1.0.271 | 57,653 | 12/30/2025 |
| 1.0.270 | 60,208 | 12/29/2025 |
| 1.0.269 | 78,690 | 12/26/2025 |
| 1.0.268 | 78,714 | 12/26/2025 |
| 1.0.267 | 78,758 | 12/26/2025 |
| 1.0.266 | 78,767 | 12/26/2025 |