Semaphore.TryOpenExisting 方法
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。
多載
TryOpenExisting(String, Semaphore) |
開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。 |
TryOpenExisting(String, SemaphoreRights, Semaphore) |
使用所需的安全性存取權,開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。 |
TryOpenExisting(String, Semaphore)
開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。
public:
static bool TryOpenExisting(System::String ^ name, [Runtime::InteropServices::Out] System::Threading::Semaphore ^ % result);
public static bool TryOpenExisting (string name, out System.Threading.Semaphore result);
[System.Runtime.Versioning.SupportedOSPlatform("windows")]
public static bool TryOpenExisting (string name, out System.Threading.Semaphore? result);
public static bool TryOpenExisting (string name, out System.Threading.Semaphore? result);
static member TryOpenExisting : string * Semaphore -> bool
[<System.Runtime.Versioning.SupportedOSPlatform("windows")>]
static member TryOpenExisting : string * Semaphore -> bool
Public Shared Function TryOpenExisting (name As String, ByRef result As Semaphore) As Boolean
參數
- name
- String
要與其他處理序共用之同步物件的名稱。 名稱區分大小寫。
傳回
如果已成功開啟具名號誌,則為 true
;否則為 false
。 在某些情況下,可能會因為名稱無效而傳回 false
。
- 屬性
例外狀況
name
上所宣告的預設值是 null
。
name
無效。 這可能基於數種原因,其中包括可能由作業系統設定的一些限制,例如未知前置詞或無效字元。 請注意,名稱與通用前置詞 "Global" 與 "Local" 會區分大小寫。 針對某些無效的名稱,方法可能會改為傳回 false
。
-或-
發生一些其他錯誤。 HResult
屬性可提供詳細資訊。
name
太長。 長度限制可能會取決於作業系統或設定。
具名的信號已存在,但使用者沒有使用它所需的安全性存取權。
備註
name
前面可能會加上 Global\
或 Local\
,以指定命名空間。 Global
指定命名空間時,同步處理物件可能會與系統上的任何進程共用。 Local
指定命名空間時,這也是未指定命名空間時的預設值,同步處理物件可能會與相同會話中的進程共用。 在Windows上,會話是登入會話,而且服務通常會在不同的非互動式會話中執行。 在類似 Unix 的作業系統上,每個殼層都有自己的會話。 會話本機同步處理物件可能適用于在進程與父/子關聯性之間同步處理,其中它們全都在相同會話中執行。 如需同步處理Windows物件名稱的詳細資訊,請參閱物件名稱。
如果命名空間中存在要求的同步處理物件,則會開啟現有的同步處理物件。 如果命名空間中不存在同步處理物件,或命名空間中存在不同類型的同步處理物件, false
則會傳回 。
若要在系統旗號不存在時建立,請使用其中一個 name
具有 參數的 Semaphore 建構函式。
如果您不確定具名旗號是否存在,請使用這個方法多載,而不是 OpenExisting(String) 方法多載,這會在旗號不存在時擲回例外狀況。
這個方法多載相當於呼叫 TryOpenExisting 方法多載,並使用 SemaphoreRights.Synchronize 位 OR 運算來指定 和 SemaphoreRights.Modify 許可權。 指定 SemaphoreRights.Synchronize 旗標可讓執行緒進入旗號,並指定 SemaphoreRights.Modify 旗標可讓執行緒呼叫 Release 方法。
適用於
TryOpenExisting(String, SemaphoreRights, Semaphore)
使用所需的安全性存取權,開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。
public:
static bool TryOpenExisting(System::String ^ name, System::Security::AccessControl::SemaphoreRights rights, [Runtime::InteropServices::Out] System::Threading::Semaphore ^ % result);
public static bool TryOpenExisting (string name, System.Security.AccessControl.SemaphoreRights rights, out System.Threading.Semaphore result);
static member TryOpenExisting : string * System.Security.AccessControl.SemaphoreRights * Semaphore -> bool
Public Shared Function TryOpenExisting (name As String, rights As SemaphoreRights, ByRef result As Semaphore) As Boolean
參數
- name
- String
要與其他處理序共用之同步物件的名稱。 名稱區分大小寫。
- rights
- SemaphoreRights
列舉值的位元組合,表示所需的安全性存取。
傳回
如果已成功開啟具名號誌,則為 true
;否則為 false
。 在某些情況下,可能會因為名稱無效而傳回 false
。
例外狀況
name
上所宣告的預設值是 null
。
name
無效。 這可能基於數種原因,其中包括可能由作業系統設定的一些限制,例如未知前置詞或無效字元。 請注意,名稱與通用前置詞 "Global" 與 "Local" 會區分大小寫。 針對某些無效的名稱,方法可能會改為傳回 false
。
-或-
發生一些其他錯誤。 HResult
屬性可提供詳細資訊。
name
太長。 長度限制可能會取決於作業系統或設定。
具名的信號已存在,但使用者沒有使用它所需的安全性存取權。
備註
name
前面可能會加上 Global\
或 Local\
,以指定命名空間。 Global
指定命名空間時,同步處理物件可能會與系統上的任何進程共用。 Local
指定命名空間時,這也是未指定命名空間時的預設值,同步處理物件可能會與相同會話中的進程共用。 在Windows上,會話是登入會話,而且服務通常會在不同的非互動式會話中執行。 在類似 Unix 的作業系統上,每個殼層都有自己的會話。 會話本機同步處理物件可能適用于在進程與父/子關聯性之間同步處理,其中它們全都在相同會話中執行。 如需同步處理Windows物件名稱的詳細資訊,請參閱物件名稱。
如果命名空間中存在要求的同步處理物件,則會開啟現有的同步處理物件。 如果命名空間中不存在同步處理物件,或命名空間中存在不同類型的同步處理物件, false
則會傳回 。
若要在系統旗號不存在時建立,請使用其中一個 name
具有 參數的 Semaphore 建構函式。
如果您不確定具名旗號是否存在,請使用這個方法多載,而不是 OpenExisting(String, SemaphoreRights) 方法多載,這會在旗號不存在時擲回例外狀況。
參數 rights
必須包含 SemaphoreRights.Synchronize 旗標,以允許執行緒輸入旗號,以及 SemaphoreRights.Modify 允許執行緒呼叫 方法的 Release 旗標。
對這個方法使用相同值的 name
多個呼叫不一定傳回相同的 Semaphore 物件,即使傳回的物件代表相同的具名系統旗號也一樣。