Semaphore.TryOpenExisting 方法
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。
多載
TryOpenExisting(String, Semaphore) |
開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。 |
TryOpenExisting(String, SemaphoreRights, Semaphore) |
使用所需的安全性存取權,開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。 |
TryOpenExisting(String, Semaphore)
- 來源:
- Semaphore.cs
- 來源:
- Semaphore.cs
- 來源:
- Semaphore.cs
開啟指定的具名號誌 (如果已經存在),並傳回值,指出作業是否成功。
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
要與其他處理序共用之同步物件的名稱。 名稱區分大小寫。 (\) 保留反斜杠字元,而且只能用來指定命名空間。 如需命名空間的詳細資訊,請參閱一節。 視操作系統而定,名稱可能會有進一步的限制。 例如,在 Unix 作業系統上,排除命名空間之後的名稱必須是有效的檔名。
傳回
如果已成功開啟具名號誌,則為 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 和 SemaphoreRights.Modify 許可權,並使用位 OR 作業結合。 指定 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
要與其他處理序共用之同步物件的名稱。 名稱區分大小寫。 (\) 保留反斜杠字元,而且只能用來指定命名空間。 如需命名空間的詳細資訊,請參閱一節。 視操作系統而定,名稱可能會有進一步的限制。 例如,在 Unix 作業系統上,排除命名空間之後的名稱必須是有效的檔名。
- 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 具名系統號誌也一樣。