SpinLock.TryEnter Method
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, lockTaken
can be examined reliably to determine whether the lock was acquired.
TryEnter(Boolean) |
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, |
TryEnter(Int32, Boolean) |
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, |
TryEnter(TimeSpan, Boolean) |
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, |
- Source:
- SpinLock.cs
- Source:
- SpinLock.cs
- Source:
- SpinLock.cs
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, lockTaken
can be examined reliably to determine whether the lock was acquired.
public:
void TryEnter(bool % lockTaken);
public void TryEnter (ref bool lockTaken);
member this.TryEnter : bool -> unit
Public Sub TryEnter (ByRef lockTaken As Boolean)
Parameters
- lockTaken
- Boolean
True if the lock is acquired; otherwise, false. lockTaken
must be initialized to false prior to calling this method.
Exceptions
The lockTaken
argument must be initialized to false prior to calling TryEnter.
Thread ownership tracking is enabled, and the current thread has already acquired this lock.
Remarks
Unlike Enter, TryEnter will not block waiting for the lock to be available. If the lock is not available when TryEnter is called, it will return immediately without any further spinning.
See also
- SpinLock
- How to: Use SpinLock for Low-Level Synchronization
- How to: Enable Thread-Tracking Mode in SpinLock
Applies to
.NET 9 and other versions
Product | Versions |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1 |
UWP | 10.0 |
- Source:
- SpinLock.cs
- Source:
- SpinLock.cs
- Source:
- SpinLock.cs
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, lockTaken
can be examined reliably to determine whether the lock was acquired.
public:
void TryEnter(int millisecondsTimeout, bool % lockTaken);
public void TryEnter (int millisecondsTimeout, ref bool lockTaken);
member this.TryEnter : int * bool -> unit
Public Sub TryEnter (millisecondsTimeout As Integer, ByRef lockTaken As Boolean)
Parameters
- millisecondsTimeout
- Int32
The number of milliseconds to wait, or Infinite (-1) to wait indefinitely.
- lockTaken
- Boolean
True if the lock is acquired; otherwise, false. lockTaken
must be initialized to false prior to calling this method.
Exceptions
millisecondsTimeout
is a negative number other than -1, which represents an infinite time-out.
The lockTaken
argument must be initialized to false prior to calling TryEnter.
Thread ownership tracking is enabled, and the current thread has already acquired this lock.
Remarks
Unlike Enter, TryEnter will not block indefinitely waiting for the lock to be available. It will block until either the lock is available or until the millisecondsTimeout
has expired.
See also
- SpinLock
- How to: Use SpinLock for Low-Level Synchronization
- How to: Enable Thread-Tracking Mode in SpinLock
Applies to
.NET 9 and other versions
Product | Versions |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1 |
UWP | 10.0 |
- Source:
- SpinLock.cs
- Source:
- SpinLock.cs
- Source:
- SpinLock.cs
Attempts to acquire the lock in a reliable manner, such that even if an exception occurs within the method call, lockTaken
can be examined reliably to determine whether the lock was acquired.
public:
void TryEnter(TimeSpan timeout, bool % lockTaken);
public void TryEnter (TimeSpan timeout, ref bool lockTaken);
member this.TryEnter : TimeSpan * bool -> unit
Public Sub TryEnter (timeout As TimeSpan, ByRef lockTaken As Boolean)
Parameters
- timeout
- TimeSpan
A TimeSpan that represents the number of milliseconds to wait, or a TimeSpan that represents -1 milliseconds to wait indefinitely.
- lockTaken
- Boolean
True if the lock is acquired; otherwise, false. lockTaken
must be initialized to false prior to calling this method.
Exceptions
timeout
is a negative number other than -1 milliseconds, which represents an infinite time-out -or- timeout is greater than Int32.MaxValue milliseconds.
The lockTaken
argument must be initialized to false prior to calling TryEnter.
Thread ownership tracking is enabled, and the current thread has already acquired this lock.
Remarks
Unlike Enter, TryEnter will not block indefinitely waiting for the lock to be available. It will block until either the lock is available or until the timeout
has expired.
See also
- SpinLock
- How to: Use SpinLock for Low-Level Synchronization
- How to: Enable Thread-Tracking Mode in SpinLock
Applies to
.NET 9 and other versions
Product | Versions |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1 |
UWP | 10.0 |
.NET feedback
.NET is an open source project. Select a link to provide feedback: