Fast lightweight in-memory queue that stores data in a concurrent queue and periodically process the queued items.
Useful for:
- processing items in batches;
- grouping data for later processing;
- async processing (consumer/producer);
- etc.
Note: this nuget package contains c# source code and depends on System.Collections.Concurrent introduced in .Net 4.0.
You can install using NuGet, see SimpleHelpers.TimedQueue at NuGet.org
PM> Install-Package SimpleHelpers.TimedQueue
The nuget package contains C# source code.
The source code will be installed in your project with the following file system structure:
|-- <project root>
|-- SimpleHelpers
|-- TimedQueue.cs
If you prefer, you can also download the source code: TimedQueue.cs
Simple configuration of the TimedQueue settings.
// create our timedQueue instance
SimpleHelpers.TimedQueue<LogEvent> my_queue = new SimpleHelpers.TimedQueue<LogEvent> ();
// set the queue timed task to run each 500 ms executing the registered action
my_queue.TimerStep = TimeSpan.FromMilliseconds (500);
// Our event, if we want to treat the removed expired items
my_queue.OnExecution = (IEnumerable<Our_Object> items) =>
{
// the items IEnumerable must be consumed to clear the queued items!
foreach (var evt in items)
// do something
};
Another example passing the parameters to the constructor.
// create our timedQueue instance
SimpleHelpers.TimedQueue<Our_Object> my_queue = new SimpleHelpers.TimedQueue<Our_Object> (TimeSpan.FromMilliseconds (2500), ConsumerMethod);
!!! note
Remember that since TimedQueue is executed asynchronously - in a timer thread - you should hold the reference to TimedQueue instance to avoid the instance destruction before the `OnExecution` method is invoked. The .Net garbage collector will collect all instances without that it thinks are not being used, and that may includes local method variables that are optimized by the compiler depending on how you coded it...
Enqueue items to be processed by the OnExecution
action.
my_queue.Put (evt);
More complex example:
// our method that does an network call to store out object
// and keeps retrying in case of failure
public static void SaveEvent (Our_Object evt)
{
// try to save
try
{
SaveOverTheInternet (evt);
}
catch (System.IO.IOException ex)
{
// log.Error (ex);
SimpleHelpers.TimedQueue<Our_Object>.Put (evt);
}
}