Synchronization helper: a static lock collection associated with a key.
NamedLock manages the lifetime of critical sections that can be accessed by a key (name) throughout the application. It also have some helper methods to allow a maximum wait time (timeout) to acquire the lock and safely release it.
You can install using NuGet, see SimpleHelpers.NamedLock at NuGet.org
PM> Install-Package SimpleHelpers.NamedLock
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
|-- NamedLock.cs
If you prefer, you can also download the source code: NamedLock.cs
Simple usage where we try to acquire the lock for 100 ms. So if somewhere else in our application this same lock was already acquired, we will wait until we acquire the lock or 100 ms has passed.
string key = "our lock name";
using (var padlock = new NamedLock (key))
{
if (padlock.Enter (TimeSpan.FromMilliseconds (100)))
{
// do something as we now own the lock
}
else
{
// do some other thing since we could not acquire the lock
}
}
Another usage example with a static helper method.
string key = "our lock name";
using (var padlock = NamedLock.CreateAndEnter (key, TimeSpan.FromMilliseconds (100)))
{
if (padlock.IsLocked)
{
// do something
}
}