次の方法で共有


SpinLock.TryEnter メソッド

定義

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

オーバーロード

TryEnter(Boolean)

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

TryEnter(Int32, Boolean)

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

TryEnter(TimeSpan, Boolean)

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

TryEnter(Boolean)

ソース:
SpinLock.cs
ソース:
SpinLock.cs
ソース:
SpinLock.cs

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

public:
 void TryEnter(bool % lockTaken);
public void TryEnter (ref bool lockTaken);
member this.TryEnter : bool -> unit
Public Sub TryEnter (ByRef lockTaken As Boolean)

パラメーター

lockTaken
Boolean

ロックが取得された場合は true。それ以外の場合は false。 このメソッドを呼び出す前に、lockTaken を false に初期化する必要があります。

例外

lockTaken 引数は、TryEnter を呼び出す前に false に初期化する必要があります。

スレッドの所有権の追跡が有効で、現在のスレッドは既にこのロックを取得しています。

注釈

とは異なり Enter、TryEnter はロックが使用可能になるのを待つのをブロックしません。 TryEnter が呼び出されたときにロックが使用できない場合は、それ以上回転することなくすぐに戻ります。

こちらもご覧ください

適用対象

TryEnter(Int32, Boolean)

ソース:
SpinLock.cs
ソース:
SpinLock.cs
ソース:
SpinLock.cs

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

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)

パラメーター

millisecondsTimeout
Int32

待機するミリ秒数。無制限に待機する場合は Infinite (-1)。

lockTaken
Boolean

ロックが取得された場合は true。それ以外の場合は false。 このメソッドを呼び出す前に、lockTaken を false に初期化する必要があります。

例外

millisecondsTimeout は無限のタイムアウトを表す -1 以外の負の数です。

lockTaken 引数は、TryEnter を呼び出す前に false に初期化する必要があります。

スレッドの所有権の追跡が有効で、現在のスレッドは既にこのロックを取得しています。

注釈

とは異なり Enter、TryEnter はロックが使用可能になるのを無期限に待機することをブロックしません。 ロックが使用可能になるまで、または が期限切れになるまで millisecondsTimeout ブロックされます。

こちらもご覧ください

適用対象

TryEnter(TimeSpan, Boolean)

ソース:
SpinLock.cs
ソース:
SpinLock.cs
ソース:
SpinLock.cs

メソッド呼び出し内で例外が発生した場合でも、lockTaken を確実に確認して、ロックが取得されたかどうかを判断できるような信頼性の高い方法で、ロックの取得を試みます。

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)

パラメーター

timeout
TimeSpan

待機するミリ秒数を表す TimeSpan。無制限に待機する場合は、-1 ミリ秒を表す TimeSpan

lockTaken
Boolean

ロックが取得された場合は true。それ以外の場合は false。 このメソッドを呼び出す前に、lockTaken を false に初期化する必要があります。

例外

timeout は-1 ミリ秒以外の負の数で、無限タイムアウトを表します。タイムアウトが Int32.MaxValue ミリ秒を超えています。

lockTaken 引数は、TryEnter を呼び出す前に false に初期化する必要があります。

スレッドの所有権の追跡が有効で、現在のスレッドは既にこのロックを取得しています。

注釈

とは異なり Enter、TryEnter はロックが使用可能になるのを無期限に待機することをブロックしません。 ロックが使用可能になるまで、または が期限切れになるまで timeout ブロックされます。

こちらもご覧ください

適用対象