Mutex Konstruktory

Definice

Inicializuje novou instanci Mutex třídy.

Přetížení

Name Description
Mutex()

Inicializuje novou instanci Mutex třídy s výchozími vlastnostmi.

Mutex(Boolean)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex.

Mutex(Boolean, String)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, a řetězec, který je názvem mutex.

Mutex(String, NamedWaitHandleOptions)

Inicializuje novou instanci Mutex třídy s řetězcem, který je názvem mutex a možnostmi pro nastavení uživatelského oboru a přístupu k oboru relace. Volající vlákno nevyžaduje počáteční vlastnictví mutexu.

Mutex(Boolean, String, Boolean)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, řetězec, který je název mutex a logická hodnota, která, když metoda vrátí, označuje, zda volající vlákno bylo uděleno počáteční vlastnictví mutex.

Mutex(Boolean, String, NamedWaitHandleOptions)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která indikuje, zda volající vlákno má mít počáteční vlastnictví mutex, řetězec, který je název mutex a možnosti pro nastavení přístupu k oboru uživatele a relace.

Mutex(Boolean, String, Boolean, MutexSecurity)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, řetězec, který je název mutex, logická proměnná, která, když metoda vrátí, označuje, zda volající vlákno bylo uděleno počáteční vlastnictví mutex a zabezpečení řízení přístupu, které se má použít na pojmenovaný mutex.

Mutex(Boolean, String, NamedWaitHandleOptions, Boolean)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, řetězec, který je název mutex, možnosti nastavit uživatelský obor a relace-obor přístupu, a logickou hodnotu, která, když metoda vrátí, označuje, zda volající vlákno bylo uděleno počáteční vlastnictví mutex.

Mutex()

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s výchozími vlastnostmi.

public:
 Mutex();
public Mutex();
Public Sub New ()

Příklady

Následující příklad kódu ukazuje, jak se místní Mutex objekt používá k synchronizaci přístupu k chráněnému prostředku. Vlákno, které vytvoří mutex, ho zpočátku nevlastní.

// This example shows how a Mutex is used to synchronize access
// to a protected resource. Unlike Monitor, Mutex can be used with
// WaitHandle.WaitAll and WaitAny, and can be passed across
// AppDomain boundaries.
 
using System;
using System.Threading;

class Test13
{
    // Create a new Mutex. The creating thread does not own the
    // Mutex.
    private static Mutex mut = new Mutex();
    private const int numIterations = 1;
    private const int numThreads = 3;

    static void Main()
    {
        // Create the threads that will use the protected resource.
        for(int i = 0; i < numThreads; i++)
        {
            Thread myThread = new Thread(new ThreadStart(MyThreadProc));
            myThread.Name = String.Format("Thread{0}", i + 1);
            myThread.Start();
        }

        // The main thread exits, but the application continues to
        // run until all foreground threads have exited.
    }

    private static void MyThreadProc()
    {
        for(int i = 0; i < numIterations; i++)
        {
            UseResource();
        }
    }

    // This method represents a resource that must be synchronized
    // so that only one thread at a time can enter.
    private static void UseResource()
    {
        // Wait until it is safe to enter.
        mut.WaitOne();

        Console.WriteLine("{0} has entered the protected area", 
            Thread.CurrentThread.Name);

        // Place code to access non-reentrant resources here.

        // Simulate some work.
        Thread.Sleep(500);

        Console.WriteLine("{0} is leaving the protected area\r\n", 
            Thread.CurrentThread.Name);
         
        // Release the Mutex.
        mut.ReleaseMutex();
    }
}
' This example shows how a Mutex is used to synchronize access
' to a protected resource. Unlike Monitor, Mutex can be used with
' WaitHandle.WaitAll and WaitAny, and can be passed across
' AppDomain boundaries.
 
Imports System.Threading

Class Test
    ' Create a new Mutex. The creating thread does not own the
    ' Mutex.
    Private Shared mut As New Mutex()
    Private Const numIterations As Integer = 1
    Private Const numThreads As Integer = 3

    <MTAThread> _
    Shared Sub Main()
        ' Create the threads that will use the protected resource.
        Dim i As Integer
        For i = 1 To numThreads
            Dim myThread As New Thread(AddressOf MyThreadProc)
            myThread.Name = [String].Format("Thread{0}", i)
            myThread.Start()
        Next i

        ' The main thread exits, but the application continues to
        ' run until all foreground threads have exited.

    End Sub

    Private Shared Sub MyThreadProc()
        Dim i As Integer
        For i = 1 To numIterations
            UseResource()
        Next i
    End Sub

    ' This method represents a resource that must be synchronized
    ' so that only one thread at a time can enter.
    Private Shared Sub UseResource()
        ' Wait until it is safe to enter.
        mut.WaitOne()

        Console.WriteLine("{0} has entered protected area", _
            Thread.CurrentThread.Name)

        ' Place code to access non-reentrant resources here.

        ' Simulate some work
        Thread.Sleep(500)

        Console.WriteLine("{0} is leaving protected area" & vbCrLf, _
            Thread.CurrentThread.Name)

        ' Release Mutex.
        mut.ReleaseMutex()
    End Sub
End Class

Poznámky

Volání tohoto přetížení konstruktoru je stejné jako volání přetížení konstruktoru Mutex(Boolean) a určení false pro počáteční vlastnictví mutex. To znamená, že volající vlákno nevlastní mutex.

Viz také

Platí pro

Mutex(Boolean)

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex.

public:
 Mutex(bool initiallyOwned);
public Mutex(bool initiallyOwned);
new System.Threading.Mutex : bool -> System.Threading.Mutex
Public Sub New (initiallyOwned As Boolean)

Parametry

initiallyOwned
Boolean

trueposkytnout volající vlákno počáteční vlastnictví mutex; v opačném případě . false

Příklady

Následující příklad kódu ukazuje, jak se místní Mutex objekt používá k synchronizaci přístupu k chráněnému prostředku. Vlákno, které ho zpočátku vytvoří Mutex , vlastní.

using System;
using System.Threading;

class Test
{
    private static Mutex mut;
    private const int numIterations = 1;
    private const int numThreads = 3;

    static void Main()
    {
        // Create a new Mutex. The creating thread owns the Mutex.
        mut = new Mutex(true);
        // Create the threads that will use the protected resource.
        for(int i = 0; i < numThreads; i++)
        {
            Thread myThread = new Thread(new ThreadStart(MyThreadProc));
            myThread.Name = String.Format("Thread{0}", i + 1);
            myThread.Start();
        }

        // Wait one second before allowing other threads to
        // acquire the Mutex.
        Console.WriteLine("Creating thread owns the Mutex.");
        Thread.Sleep(1000);

        Console.WriteLine("Creating thread releases the Mutex.\r\n");
        mut.ReleaseMutex();
    }

    private static void MyThreadProc()
    {
        for(int i = 0; i < numIterations; i++)
        {
            UseResource();
        }
    }

    // This method represents a resource that must be synchronized
    // so that only one thread at a time can enter.
    private static void UseResource()
    {
        // Wait until it is safe to enter.
        mut.WaitOne();

        Console.WriteLine("{0} has entered the protected area", 
            Thread.CurrentThread.Name);

        // Place code to access non-reentrant resources here.

        // Simulate some work.
        Thread.Sleep(500);

        Console.WriteLine("{0} is leaving the protected area\r\n", 
            Thread.CurrentThread.Name);
         
        // Release the Mutex.
        mut.ReleaseMutex();
    }
}
// The example displays output like the following:
//       Creating thread owns the Mutex.
//       Creating thread releases the Mutex.
//       
//       Thread1 has entered the protected area
//       Thread1 is leaving the protected area
//       
//       Thread2 has entered the protected area
//       Thread2 is leaving the protected area
//       
//       Thread3 has entered the protected area
//       Thread3 is leaving the protected area
Imports System.Threading

Class Test
    ' Create a new Mutex. The creating thread owns the
    ' Mutex.
    Private Shared mut As New Mutex(True)
    Private Const numIterations As Integer = 1
    Private Const numThreads As Integer = 3

    <MTAThread> _
    Shared Sub Main()
        ' Create the threads that will use the protected resource.
        Dim i As Integer
        For i = 1 To numThreads
            Dim myThread As New Thread(AddressOf MyThreadProc)
            myThread.Name = [String].Format("Thread{0}", i)
            myThread.Start()
        Next i

        ' Wait one second before allowing other threads to
        ' acquire the Mutex.
        Console.WriteLine("Creating thread owns the Mutex.")
        Thread.Sleep(1000)

        Console.WriteLine("Creating thread releases the Mutex." & vbCrLf)
        mut.ReleaseMutex()
    End Sub

    Private Shared Sub MyThreadProc()
        Dim i As Integer
        For i = 1 To numIterations
            UseResource()
        Next i
    End Sub

    ' This method represents a resource that must be synchronized
    ' so that only one thread at a time can enter.
    Private Shared Sub UseResource()
        ' Wait until it is safe to enter.
        mut.WaitOne()

        Console.WriteLine("{0} has entered protected area", _
            Thread.CurrentThread.Name)

        ' Place code to access non-reentrant resources here.

        ' Simulate some work
        Thread.Sleep(500)

        Console.WriteLine("{0} is leaving protected area" & vbCrLf, _
            Thread.CurrentThread.Name)

        ' Release Mutex.
        mut.ReleaseMutex()
    End Sub
End Class
' The example displays output like the following:
'       Creating thread owns the Mutex.
'       Creating thread releases the Mutex.
'       
'       Thread1 has entered the protected area
'       Thread1 is leaving the protected area
'       
'       Thread2 has entered the protected area
'       Thread2 is leaving the protected area
'       
'       Thread3 has entered the protected area
'       Thread3 is leaving the protected area

Viz také

Platí pro

Mutex(Boolean, String)

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, a řetězec, který je názvem mutex.

public:
 Mutex(bool initiallyOwned, System::String ^ name);
[System.Security.SecurityCritical]
public Mutex(bool initiallyOwned, string name);
public Mutex(bool initiallyOwned, string? name);
public Mutex(bool initiallyOwned, string name);
[<System.Security.SecurityCritical>]
new System.Threading.Mutex : bool * string -> System.Threading.Mutex
new System.Threading.Mutex : bool * string -> System.Threading.Mutex
Public Sub New (initiallyOwned As Boolean, name As String)

Parametry

initiallyOwned
Boolean

trueposkytnout volající vlákno počáteční vlastnictví pojmenovaného systému mutex pokud pojmenovaný systém mutex je vytvořen v důsledku tohoto volání; v opačném případě . false

name
String

Název, pokud je synchronizační objekt sdílen s jinými procesy; null v opačném případě nebo prázdný řetězec. V názvu se rozlišují malá a velká písmena. Znak zpětného lomítka (\) je vyhrazen a lze ho použít pouze k určení oboru názvů. Další informace o oborech názvů najdete v části Poznámky. V závislosti na operačním systému můžou existovat další omezení názvu. Například v operačních systémech se systémem Unix musí být název po vyloučení oboru názvů platným názvem souboru.

Atributy

Výjimky

Pojmenovaný mutex existuje a má zabezpečení řízení přístupu, ale uživatel nemá FullControl.

name je neplatný. Může to být z různých důvodů, včetně některých omezení, která může operační systém umístit, například neznámé předpony nebo neplatné znaky. Všimněte si, že název a běžné předpony "Global\" a "Local\" rozlišují malá a velká písmena.

nebo

Došlo k nějaké jiné chybě. Vlastnost HResult může poskytnout další informace.

pouze Windows: name zadal neznámý obor názvů. Další informace najdete v tématu Názvy objektů .

name je příliš dlouhý. Omezení délky můžou záviset na operačním systému nebo konfiguraci.

Synchronizační objekt se zadaným objektem name nelze vytvořit. Synchronizační objekt jiného typu může mít stejný název.

pouze .NET Framework: name je delší než MAX_PATH (260 znaků).

Příklady

Následující příklad ukazuje, jak se pojmenovaný mutex používá k signalizaci mezi vlákny spuštěnými ve dvou samostatných procesech.

Spusťte tento program ze dvou nebo více oken příkazů. Každý proces vytvoří Mutex objekt, který představuje pojmenovaný mutex MyMutex. Pojmenovaný mutex je systémový objekt, jehož životnost je ohraničena životností Mutex objektů, které ho představují. Pojmenovaný mutex se vytvoří při prvním procesu, který vytvoří jeho Mutex objekt. V tomto příkladu je pojmenovaný mutex vlastněný prvním procesem, který program spouští. Pojmenovaný mutex je zničen, když byly uvolněny všechny Mutex objekty, které představují.

Přetížení konstruktoru použité v tomto příkladu nemůže informovat volající vlákno, zda bylo uděleno počáteční vlastnictví pojmenovaného mutex. Tento konstruktor byste neměli použít k vyžádání počátečního vlastnictví, pokud si nejste jisti, že vlákno vytvoří pojmenovaný mutex.

using System;
using System.Threading;

public class Test1
{
    public static void Main()
    {
        // Create the named mutex. Only one system object named 
        // "MyMutex" can exist; the local Mutex object represents 
        // this system object, regardless of which process or thread
        // caused "MyMutex" to be created.
        Mutex m = new Mutex(false, "MyMutex");
        
        // Try to gain control of the named mutex. If the mutex is 
        // controlled by another thread, wait for it to be released.        
        Console.WriteLine("Waiting for the Mutex.");
        m.WaitOne();

        // Keep control of the mutex until the user presses
        // ENTER.
        Console.WriteLine("This application owns the mutex. " +
            "Press ENTER to release the mutex and exit.");
        Console.ReadLine();

        m.ReleaseMutex();
    }
}
Imports System.Threading

Public Class Test
   Public Shared Sub Main()
      ' Create the named mutex. Only one system object named 
      ' "MyMutex" can exist; the local Mutex object represents 
      ' this system object, regardless of which process or thread
      ' caused "MyMutex" to be created.
      Dim m As New Mutex(False, "MyMutex")
      
      ' Try to gain control of the named mutex. If the mutex is 
      ' controlled by another thread, wait for it to be released.        
      Console.WriteLine("Waiting for the Mutex.")
      m.WaitOne()
      
      ' Keep control of the mutex until the user presses
      ' ENTER.
      Console.WriteLine("This application owns the mutex. " _
          & "Press ENTER to release the mutex and exit.")
      Console.ReadLine()
      
      m.ReleaseMutex()
   End Sub 
End Class

Poznámky

Může name mít předponu Global\ nebo Local\ zadat obor názvů. Global Po zadání oboru názvů může být synchronizační objekt sdílen se všemi procesy v systému. Local Pokud je zadán obor názvů, což je také výchozí, pokud není zadán žádný obor názvů, synchronizační objekt může být sdílen s procesy ve stejné relaci. Na Windows je relace relace přihlášení a služby se obvykle spouští v jiné neinteraktivní relaci. V operačních systémech Unix má každé prostředí vlastní relaci. Objekty místní synchronizace relace můžou být vhodné pro synchronizaci mezi procesy s vztahem nadřazenosti nebo podřízenosti, kde se všechny spouští ve stejné relaci. Další informace o názvech synchronizačních objektů v Windows najdete v tématu Názvové objektyobjektu.

name Pokud je zadána a synchronizační objekt požadovaného typu již v oboru názvů existuje, použije se existující objekt synchronizace. Pokud synchronizační objekt jiného typu již v oboru názvů existuje, WaitHandleCannotBeOpenedException vyvolá se vyvolá. V opačném případě se vytvoří nový synchronizační objekt.

Pokud name není null a initiallyOwned není true, volající vlákno vlastní mutex pouze v případě, že pojmenovaný systémový mutex byl vytvořen v důsledku tohoto volání. Vzhledem k tomu, že neexistuje žádný mechanismus pro určení, zda pojmenovaný systém mutex byl vytvořen, je lepší určit false při initiallyOwned volání tohoto přetížení konstruktoru. Konstruktor můžete použít Mutex(Boolean, String, Boolean) , pokud potřebujete určit počáteční vlastnictví.

Tento konstruktor inicializuje Mutex objekt, který představuje pojmenovaný systémový mutex. Můžete vytvořit více Mutex objektů, které představují stejný pojmenovaný systémový mutex.

Pokud již byl pojmenovaný mutex vytvořen se zabezpečením řízení přístupu a volající nemá MutexRights.FullControl, vyvolá se výjimka. Pokud chcete otevřít existující pojmenovaný mutex pouze s těmito oprávněními potřebnými pro synchronizaci aktivit vlákna, přečtěte si tuto metodu OpenExisting .

Pokud zadáte null nebo prázdný řetězec pro name, vytvoří se místní mutex, jako byste volali Mutex(Boolean) konstruktor.

Vzhledem k tomu, že se jedná o systémové, pojmenované mutexy lze použít ke koordinaci využití prostředků napříč hranicemi procesu.

Note

Na serveru se spuštěnou terminálovou službou může pojmenovaný systémový mutex mít dvě úrovně viditelnosti. Pokud název začíná předponou Global\, je mutex viditelný ve všech relacích terminálového serveru. Pokud jeho název začíná předponou Local\, je mutex viditelný pouze v relaci terminálového serveru, kde byla vytvořena. V takovém případě může existovat samostatný mutex se stejným názvem v každé druhé relaci terminálového serveru na serveru. Pokud při vytváření pojmenovaného mutex nezadáte předponu, převezme předponu Local\. V rámci relace terminálového serveru jsou dva mutexy, jejichž názvy se liší pouze podle jejich předpon, samostatné mutexy a oba jsou viditelné pro všechny procesy v relaci terminálového serveru. To znamená, že názvy Global\ předpon a Local\ popisují rozsah názvu mutex vzhledem k relacím terminálového serveru, nikoli vzhledem k procesům.

Caution

Ve výchozím nastavení není pojmenovaný mutex omezen na uživatele, který ho vytvořil. Ostatní uživatelé mohou být schopni otevřít a používat mutex, včetně zasahování do mutexu zadáním mutexu a jeho ukončením. V operačníchsystémechch Windows Pokud chcete omezit přístup konkrétním uživatelům, můžete při vytváření pojmenovaného mutex použít přetížení konstruktoru nebo MutexAcl a předat MutexSecurity. V operačních systémech unixových systémů v současné době neexistuje způsob, jak omezit přístup k pojmenované mutex. Vyhněte se používání pojmenovaných mutexů bez omezení přístupu v systémech, které můžou mít nedůvěryhodné uživatele se spuštěným kódem.

Zpětné lomítko (\) je vyhrazený znak v názvu mutex. Nepoužívejte zpětné lomítko (\) v názvu mutex s výjimkou toho, jak je uvedeno v poznámce při použití mutexů v relacích terminálového serveru. DirectoryNotFoundException Jinak může dojít k vyvolání, i když název mutex představuje existující soubor.

Viz také

Platí pro

Mutex(String, NamedWaitHandleOptions)

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s řetězcem, který je názvem mutex a možnostmi pro nastavení uživatelského oboru a přístupu k oboru relace. Volající vlákno nevyžaduje počáteční vlastnictví mutexu.

public:
 Mutex(System::String ^ name, System::Threading::NamedWaitHandleOptions options);
public Mutex(string? name, System.Threading.NamedWaitHandleOptions options);
new System.Threading.Mutex : string * System.Threading.NamedWaitHandleOptions -> System.Threading.Mutex
Public Sub New (name As String, options As NamedWaitHandleOptions)

Parametry

name
String

Název, pokud je synchronizační objekt sdílen s jinými procesy; null v opačném případě nebo prázdný řetězec. V názvu se rozlišují malá a velká písmena.

options
NamedWaitHandleOptions

Možnosti oboru pojmenovaného systémového mutexu. Ve výchozím nastavení je přístup omezený pouze na aktuálního uživatele a aktuální relaci. Zadané možnosti můžou mít vliv na obor názvů pro název a přístup k podkladovému systémovému objektu mutex.

Výjimky

Pojmenovaný mutex existuje a má zabezpečení řízení přístupu, ale uživatel nemá FullControl.

name je neplatný. Může to být z různých důvodů, včetně některých omezení, která může operační systém umístit, například neznámé předpony nebo neplatné znaky. Všimněte si, že název a běžné předpony "Global\" a "Local\" rozlišují malá a velká písmena.

nebo

Došlo k nějaké jiné chybě. Vlastnost HResult může poskytnout další informace.

pouze Windows: name zadal neznámý obor názvů. Další informace najdete v tématu Názvy objektů .

name je příliš dlouhý. Omezení délky můžou záviset na operačním systému nebo konfiguraci.

Synchronizační objekt se zadaným objektem name nelze vytvořit. Synchronizační objekt jiného typu může mít stejný název. nebo

Objekt se zadaným name objektem existuje, ale zadaný options objekt není kompatibilní s možnostmi existujícího objektu.

Poznámky

name Pokud je zadán a synchronizační objekt požadovaného typu již v oboru názvů existuje, použije se existující synchronizační objekt, pokud options však určuje přístup omezený na aktuálního uživatele a synchronizační objekt není s ním kompatibilní, WaitHandleCannotBeOpenedException vyvolá se. Pokud synchronizační objekt jiného typu již v oboru názvů existuje, WaitHandleCannotBeOpenedException vyvolá se i objekt synchronizace. V opačném případě se vytvoří nový synchronizační objekt.

Tento konstruktor inicializuje Mutex objekt, který představuje pojmenovaný systémový mutex. Můžete vytvořit více Mutex objektů, které představují stejný pojmenovaný systémový mutex.

Pokud již byl pojmenovaný mutex vytvořen se zabezpečením řízení přístupu a volající nemá MutexRights.FullControl, vyvolá se výjimka. Pokud chcete otevřít existující pojmenovaný mutex pouze s těmito oprávněními potřebnými pro synchronizaci aktivit vlákna, přečtěte si tuto metodu OpenExisting .

Pokud zadáte null nebo prázdný řetězec pro name, vytvoří se místní mutex, jako byste volali Mutex(Boolean) konstruktor.

Vzhledem k tomu, že se jedná o systémové, pojmenované mutexy lze použít ke koordinaci využití prostředků napříč hranicemi procesu.

Parametr options lze zadat tak, aby určil, jestli je pojmenovaný mutex přístupný pouze aktuálnímu uživateli nebo všem uživatelům. Umožňuje také určit, zda je pojmenovaný mutex přístupný pro procesy pouze v aktuální relaci nebo pro všechny relace. Další informace najdete na webu NamedWaitHandleOptions.

Zpětné lomítko (\) je vyhrazený znak v názvu mutex. Nepoužívejte zpětné lomítko (\) v názvu mutex s výjimkou toho, jak je uvedeno v poznámce při použití mutexů v relacích terminálového serveru. DirectoryNotFoundException Jinak může dojít k vyvolání, i když název mutex představuje existující soubor.

Viz také

Platí pro

Mutex(Boolean, String, Boolean)

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, řetězec, který je název mutex a logická hodnota, která, když metoda vrátí, označuje, zda volající vlákno bylo uděleno počáteční vlastnictví mutex.

public:
 Mutex(bool initiallyOwned, System::String ^ name, [Runtime::InteropServices::Out] bool % createdNew);
[System.Security.SecurityCritical]
public Mutex(bool initiallyOwned, string name, out bool createdNew);
public Mutex(bool initiallyOwned, string? name, out bool createdNew);
public Mutex(bool initiallyOwned, string name, out bool createdNew);
[<System.Security.SecurityCritical>]
new System.Threading.Mutex : bool * string * bool -> System.Threading.Mutex
new System.Threading.Mutex : bool * string * bool -> System.Threading.Mutex
Public Sub New (initiallyOwned As Boolean, name As String, ByRef createdNew As Boolean)

Parametry

initiallyOwned
Boolean

trueposkytnout volající vlákno počáteční vlastnictví pojmenovaného systému mutex pokud pojmenovaný systém mutex je vytvořen v důsledku tohoto volání; v opačném případě . false

name
String

Název, pokud je synchronizační objekt sdílen s jinými procesy; null v opačném případě nebo prázdný řetězec. V názvu se rozlišují malá a velká písmena. Znak zpětného lomítka (\) je vyhrazen a lze ho použít pouze k určení oboru názvů. Další informace o oborech názvů najdete v části Poznámky. V závislosti na operačním systému můžou existovat další omezení názvu. Například v operačních systémech se systémem Unix musí být název po vyloučení oboru názvů platným názvem souboru.

createdNew
Boolean

Pokud tato metoda vrátí, obsahuje logickou hodnotu, která je true v případě, že byl vytvořen místní mutex (tj. pokud name je null nebo prázdný řetězec) nebo pokud zadaný pojmenovaný systémový mutex byl vytvořen; false pokud zadaný pojmenovaný systémový mutex již existoval. Tento parametr se předává neinicializovaný.

Atributy

Výjimky

Pojmenovaný mutex existuje a má zabezpečení řízení přístupu, ale uživatel nemá FullControl.

name je neplatný. Může to být z různých důvodů, včetně některých omezení, která může operační systém umístit, například neznámé předpony nebo neplatné znaky. Všimněte si, že název a běžné předpony "Global\" a "Local\" rozlišují malá a velká písmena.

nebo

Došlo k nějaké jiné chybě. Vlastnost HResult může poskytnout další informace.

pouze Windows: name zadal neznámý obor názvů. Další informace najdete v tématu Názvy objektů .

name je příliš dlouhý. Omezení délky můžou záviset na operačním systému nebo konfiguraci.

Synchronizační objekt se zadaným objektem name nelze vytvořit. Synchronizační objekt jiného typu může mít stejný název.

pouze .NET Framework: name je delší než MAX_PATH (260 znaků).

Příklady

Následující příklad kódu ukazuje, jak se pojmenovaný mutex používá k signalizaci mezi procesy nebo vlákny. Spusťte tento program ze dvou nebo více oken příkazů. Každý proces vytvoří Mutex objekt, který představuje pojmenovaný mutex "MyMutex". Pojmenovaný mutex je systémový objekt. V tomto příkladu je jeho životnost ohraničena životností Mutex objektů, které ho představují. Pojmenovaný mutex se vytvoří, když první proces vytvoří jeho místní Mutex objekt, a zničen, když byly vydány všechny Mutex objekty, které představují. Pojmenovaný mutex je původně vlastněný prvním procesem. Druhý proces a všechny následné procesy čekají, až dřívější procesy uvolní pojmenovaný mutex.

// This example shows how a named mutex is used to signal between
// processes or threads.
// Run this program from two (or more) command windows. Each process
// creates a Mutex object that represents the named mutex "MyMutex".
// The named mutex is a system object whose lifetime is bounded by the
// lifetimes of the Mutex objects that represent it. The named mutex
// is created when the first process creates its local Mutex; in this
// example, the named mutex is owned by the first process. The named 
// mutex is destroyed when all the Mutex objects that represent it
// have been released. 
// The second process (and any subsequent process) waits for earlier
// processes to release the named mutex.

using System;
using System.Threading;

public class Test12
{
    public static void Main()
    {
        // Set this variable to false if you do not want to request 
        // initial ownership of the named mutex.
        bool requestInitialOwnership = true;
        bool mutexWasCreated;

        // Request initial ownership of the named mutex by passing
        // true for the first parameter. Only one system object named 
        // "MyMutex" can exist; the local Mutex object represents 
        // this system object. If "MyMutex" is created by this call,
        // then mutexWasCreated contains true; otherwise, it contains
        // false.
        Mutex m = new Mutex(requestInitialOwnership, 
                            "MyMutex", 
                            out mutexWasCreated);
        
        // This thread owns the mutex only if it both requested 
        // initial ownership and created the named mutex. Otherwise,
        // it can request the named mutex by calling WaitOne.
        if (!(requestInitialOwnership && mutexWasCreated))
        {
            Console.WriteLine("Waiting for the named mutex.");
            m.WaitOne();
        }

        // Once the process has gained control of the named mutex,
        // hold onto it until the user presses ENTER.
        Console.WriteLine("This process owns the named mutex. " +
            "Press ENTER to release the mutex and exit.");
        Console.ReadLine();

        // Call ReleaseMutex to allow other threads to gain control
        // of the named mutex. If you keep a reference to the local
        // Mutex, you can call WaitOne to request control of the 
        // named mutex.
        m.ReleaseMutex();
    }
}
' This example shows how a named mutex is used to signal between
' processes or threads.
' Run this program from two (or more) command windows. Each process
' creates a Mutex object that represents the named mutex "MyMutex".
' The named mutex is a system object whose lifetime is bounded by the
' lifetimes of the Mutex objects that represent it. The named mutex
' is created when the first process creates its local Mutex; in this
' example, the named mutex is owned by the first process. The named 
' mutex is destroyed when all the Mutex objects that represent it
' have been released. 
' The second process (and any subsequent process) waits for earlier
' processes to release the named mutex.

Imports System.Threading

Public Class Test
   
   <MTAThread> _
   Public Shared Sub Main()
      ' Set this variable to false if you do not want to request 
      ' initial ownership of the named mutex.
      Dim requestInitialOwnership As Boolean = True
      Dim mutexWasCreated As Boolean
      
      ' Request initial ownership of the named mutex by passing
      ' true for the first parameter. Only one system object named 
      ' "MyMutex" can exist; the local Mutex object represents 
      ' this system object. If "MyMutex" is created by this call,
      ' then mutexWasCreated contains true; otherwise, it contains
      ' false.
      Dim m As New Mutex(requestInitialOwnership, "MyMutex", _
          mutexWasCreated)
      
      ' This thread owns the mutex only if it both requested 
      ' initial ownership and created the named mutex. Otherwise,
      ' it can request the named mutex by calling WaitOne.
      If Not (requestInitialOwnership And mutexWasCreated) Then
         Console.WriteLine("Waiting for the named mutex.")
         m.WaitOne()
      End If
      
      ' Once the process has gained control of the named mutex,
      ' hold onto it until the user presses ENTER.
      Console.WriteLine("This process owns the named mutex. " _
          & "Press ENTER to release the mutex and exit.")
      Console.ReadLine()
      
      ' Call ReleaseMutex to allow other threads to gain control
      ' of the named mutex. If you keep a reference to the local
      ' Mutex, you can call WaitOne to request control of the 
      ' named mutex.
      m.ReleaseMutex()
   End Sub
End Class

Poznámky

Může name mít předponu Global\ nebo Local\ zadat obor názvů. Global Po zadání oboru názvů může být synchronizační objekt sdílen se všemi procesy v systému. Local Pokud je zadán obor názvů, což je také výchozí, pokud není zadán žádný obor názvů, synchronizační objekt může být sdílen s procesy ve stejné relaci. Na Windows je relace relace přihlášení a služby se obvykle spouští v jiné neinteraktivní relaci. V operačních systémech Unix má každé prostředí vlastní relaci. Objekty místní synchronizace relace můžou být vhodné pro synchronizaci mezi procesy s vztahem nadřazenosti nebo podřízenosti, kde se všechny spouští ve stejné relaci. Další informace o názvech synchronizačních objektů v Windows najdete v tématu Názvové objektyobjektu.

name Pokud je zadána a synchronizační objekt požadovaného typu již v oboru názvů existuje, použije se existující objekt synchronizace. Pokud synchronizační objekt jiného typu již v oboru názvů existuje, WaitHandleCannotBeOpenedException vyvolá se vyvolá. V opačném případě se vytvoří nový synchronizační objekt.

Pokud name není null a initiallyOwned je true, volající vlákno vlastní pojmenovaný mutex pouze v případě, že createdNew je true po volání. Jinak vlákno může požádat mutex voláním WaitOne metody.

Tento konstruktor inicializuje Mutex objekt, který představuje pojmenovaný systémový mutex. Můžete vytvořit více Mutex objektů, které představují stejný pojmenovaný systémový mutex.

Pokud již byl pojmenovaný mutex vytvořen se zabezpečením řízení přístupu a volající nemá MutexRights.FullControl práva, vyvolá se výjimka. Pokud chcete otevřít existující pojmenovaný mutex pouze s těmito oprávněními potřebnými pro synchronizaci aktivit vlákna, přečtěte si tuto metodu OpenExisting .

Pokud zadáte null nebo prázdný řetězec pro name, vytvoří se místní mutex, jako byste volali Mutex(Boolean) konstruktor. V tomto případě je createdNew vždy true.

Vzhledem k tomu, že se jedná o systémové, pojmenované mutexy lze použít ke koordinaci využití prostředků napříč hranicemi procesu.

Note

Na serveru se spuštěnou terminálovou službou může pojmenovaný systémový mutex mít dvě úrovně viditelnosti. Pokud název začíná předponou Global\, je mutex viditelný ve všech relacích terminálového serveru. Pokud jeho název začíná předponou Local\, je mutex viditelný pouze v relaci terminálového serveru, kde byla vytvořena. V takovém případě může existovat samostatný mutex se stejným názvem v každé druhé relaci terminálového serveru na serveru. Pokud při vytváření pojmenovaného mutex nezadáte předponu, převezme předponu Local\. V rámci relace terminálového serveru jsou dva mutexy, jejichž názvy se liší pouze podle jejich předpon, samostatné mutexy a oba jsou viditelné pro všechny procesy v relaci terminálového serveru. To znamená, že názvy Global\ předpon a Local\ popisují rozsah názvu mutex vzhledem k relacím terminálového serveru, nikoli vzhledem k procesům.

Caution

Ve výchozím nastavení není pojmenovaný mutex omezen na uživatele, který ho vytvořil. Ostatní uživatelé mohou být schopni otevřít a používat mutex, včetně zasahování do mutexu zadáním mutexu a jeho ukončením. V operačníchsystémechch Windows Pokud chcete omezit přístup konkrétním uživatelům, můžete při vytváření pojmenovaného mutex použít přetížení konstruktoru nebo MutexAcl a předat MutexSecurity. V operačních systémech unixových systémů v současné době neexistuje způsob, jak omezit přístup k pojmenované mutex. Vyhněte se používání pojmenovaných mutexů bez omezení přístupu v systémech, které můžou mít nedůvěryhodné uživatele se spuštěným kódem.

Zpětné lomítko (\) je vyhrazený znak v názvu mutex. Nepoužívejte zpětné lomítko (\) v názvu mutex s výjimkou toho, jak je uvedeno v poznámce při použití mutexů v relacích terminálového serveru. DirectoryNotFoundException Jinak může dojít k vyvolání, i když název mutex představuje existující soubor.

Viz také

Platí pro

Mutex(Boolean, String, NamedWaitHandleOptions)

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která indikuje, zda volající vlákno má mít počáteční vlastnictví mutex, řetězec, který je název mutex a možnosti pro nastavení přístupu k oboru uživatele a relace.

public:
 Mutex(bool initiallyOwned, System::String ^ name, System::Threading::NamedWaitHandleOptions options);
public Mutex(bool initiallyOwned, string? name, System.Threading.NamedWaitHandleOptions options);
new System.Threading.Mutex : bool * string * System.Threading.NamedWaitHandleOptions -> System.Threading.Mutex
Public Sub New (initiallyOwned As Boolean, name As String, options As NamedWaitHandleOptions)

Parametry

initiallyOwned
Boolean

trueposkytnout volající vlákno počáteční vlastnictví pojmenovaného systému mutex pokud pojmenovaný systém mutex je vytvořen v důsledku tohoto volání; v opačném případě . false

name
String

Název, pokud je synchronizační objekt sdílen s jinými procesy; null v opačném případě nebo prázdný řetězec. V názvu se rozlišují malá a velká písmena.

options
NamedWaitHandleOptions

Možnosti oboru pojmenovaného systémového mutexu. Ve výchozím nastavení je přístup omezený pouze na aktuálního uživatele a aktuální relaci. Zadané možnosti můžou mít vliv na obor názvů pro název a přístup k podkladovému systémovému objektu mutex.

Výjimky

Pojmenovaný mutex existuje a má zabezpečení řízení přístupu, ale uživatel nemá FullControl.

name je neplatný. Může to být z různých důvodů, včetně některých omezení, která může operační systém umístit, například neznámé předpony nebo neplatné znaky. Všimněte si, že název a běžné předpony "Global\" a "Local\" rozlišují malá a velká písmena.

nebo

Došlo k nějaké jiné chybě. Vlastnost HResult může poskytnout další informace.

pouze Windows: name zadal neznámý obor názvů. Další informace najdete v tématu Názvy objektů .

name je příliš dlouhý. Omezení délky můžou záviset na operačním systému nebo konfiguraci.

Synchronizační objekt se zadaným objektem name nelze vytvořit. Synchronizační objekt jiného typu může mít stejný název. nebo

Objekt se zadaným name objektem existuje, ale zadaný options objekt není kompatibilní s možnostmi existujícího objektu.

Poznámky

name Pokud je zadán a synchronizační objekt požadovaného typu již v oboru názvů existuje, použije se existující synchronizační objekt, pokud options však určuje přístup omezený na aktuálního uživatele a synchronizační objekt není s ním kompatibilní, WaitHandleCannotBeOpenedException vyvolá se. Pokud synchronizační objekt jiného typu již v oboru názvů existuje, WaitHandleCannotBeOpenedException vyvolá se i objekt synchronizace. V opačném případě se vytvoří nový synchronizační objekt.

Pokud name není null a initiallyOwned není true, volající vlákno vlastní mutex pouze v případě, že pojmenovaný systémový mutex byl vytvořen v důsledku tohoto volání. Vzhledem k tomu, že neexistuje žádný mechanismus pro určení, zda pojmenovaný systém mutex byl vytvořen, je lepší určit false při initiallyOwned volání tohoto přetížení konstruktoru. Konstruktor můžete použít Mutex(Boolean, String, Boolean) , pokud potřebujete určit počáteční vlastnictví.

Tento konstruktor inicializuje Mutex objekt, který představuje pojmenovaný systémový mutex. Můžete vytvořit více Mutex objektů, které představují stejný pojmenovaný systémový mutex.

Pokud již byl pojmenovaný mutex vytvořen se zabezpečením řízení přístupu a volající nemá MutexRights.FullControl, vyvolá se výjimka. Pokud chcete otevřít existující pojmenovaný mutex pouze s těmito oprávněními potřebnými pro synchronizaci aktivit vlákna, přečtěte si tuto metodu OpenExisting .

Pokud zadáte null nebo prázdný řetězec pro name, vytvoří se místní mutex, jako byste volali Mutex(Boolean) konstruktor.

Vzhledem k tomu, že se jedná o systémové, pojmenované mutexy lze použít ke koordinaci využití prostředků napříč hranicemi procesu.

Parametr options lze zadat tak, aby určil, jestli je pojmenovaný mutex přístupný pouze aktuálnímu uživateli nebo všem uživatelům. Umožňuje také určit, zda je pojmenovaný mutex přístupný pro procesy pouze v aktuální relaci nebo pro všechny relace. Další informace najdete na webu NamedWaitHandleOptions.

Viz také

Platí pro

Mutex(Boolean, String, Boolean, MutexSecurity)

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, řetězec, který je název mutex, logická proměnná, která, když metoda vrátí, označuje, zda volající vlákno bylo uděleno počáteční vlastnictví mutex a zabezpečení řízení přístupu, které se má použít na pojmenovaný mutex.

public:
 Mutex(bool initiallyOwned, System::String ^ name, [Runtime::InteropServices::Out] bool % createdNew, System::Security::AccessControl::MutexSecurity ^ mutexSecurity);
public Mutex(bool initiallyOwned, string name, out bool createdNew, System.Security.AccessControl.MutexSecurity mutexSecurity);
[System.Security.SecurityCritical]
public Mutex(bool initiallyOwned, string name, out bool createdNew, System.Security.AccessControl.MutexSecurity mutexSecurity);
new System.Threading.Mutex : bool * string * bool * System.Security.AccessControl.MutexSecurity -> System.Threading.Mutex
[<System.Security.SecurityCritical>]
new System.Threading.Mutex : bool * string * bool * System.Security.AccessControl.MutexSecurity -> System.Threading.Mutex
Public Sub New (initiallyOwned As Boolean, name As String, ByRef createdNew As Boolean, mutexSecurity As MutexSecurity)

Parametry

initiallyOwned
Boolean

trueposkytnout volající vlákno počáteční vlastnictví pojmenovaného systému mutex pokud pojmenovaný systém mutex je vytvořen v důsledku tohoto volání; v opačném případě . false

name
String

Název, pokud je synchronizační objekt sdílen s jinými procesy; null v opačném případě nebo prázdný řetězec. V názvu se rozlišují malá a velká písmena. Znak zpětného lomítka (\) je vyhrazen a lze ho použít pouze k určení oboru názvů. Další informace o oborech názvů najdete v části Poznámky. V závislosti na operačním systému můžou existovat další omezení názvu. Například v operačních systémech se systémem Unix musí být název po vyloučení oboru názvů platným názvem souboru.

createdNew
Boolean

Pokud tato metoda vrátí, obsahuje logickou hodnotu, která je true v případě, že byl vytvořen místní mutex (tj. pokud name je null nebo prázdný řetězec) nebo pokud zadaný pojmenovaný systémový mutex byl vytvořen; false pokud zadaný pojmenovaný systémový mutex již existoval. Tento parametr se předává neinicializovaný.

mutexSecurity
MutexSecurity

Objekt MutexSecurity , který představuje zabezpečení řízení přístupu, které se má použít na pojmenovaný systémový mutex.

Atributy

Výjimky

name je neplatný. Může to být z různých důvodů, včetně některých omezení, která může operační systém umístit, například neznámé předpony nebo neplatné znaky. Všimněte si, že název a běžné předpony "Global\" a "Local\" rozlišují malá a velká písmena.

nebo

Došlo k nějaké jiné chybě. Vlastnost HResult může poskytnout další informace.

pouze Windows: name zadal neznámý obor názvů. Další informace najdete v tématu Názvy objektů .

name je příliš dlouhý. Omezení délky můžou záviset na operačním systému nebo konfiguraci.

Pojmenovaný mutex existuje a má zabezpečení řízení přístupu, ale uživatel nemá FullControl.

Synchronizační objekt se zadaným objektem name nelze vytvořit. Synchronizační objekt jiného typu může mít stejný název.

pouze .NET Framework: name je delší než MAX_PATH (260 znaků).

Příklady

Následující příklad kódu ukazuje chování křížového procesu pojmenovaného mutex se zabezpečením řízení přístupu. Příklad používá OpenExisting(String) přetížení metody k otestování existence pojmenovaného mutex.

Pokud mutex neexistuje, vytvoří se s počátečním vlastnictvím a zabezpečením řízení přístupu, které aktuálnímu uživateli odepře právo používat mutex, ale uděluje právo číst a měnit oprávnění k mutexu.

Pokud spustíte zkompilovaný příklad ze dvou oken příkazů, druhá kopie vyvolá výjimku porušení přístupu při volání OpenExisting(String). Výjimka je zachycena a příklad používá OpenExisting(String, MutexRights) přetížení metody k otevření mutex s právy potřebnými ke čtení a změně oprávnění.

Po změně oprávnění se mutex otevře s právy potřebnými k jeho zadání a uvolnění. Pokud spustíte zkompilovaný příklad z třetího příkazového okna, spustí se pomocí nových oprávnění.

using System;
using System.Threading;
using System.Security.AccessControl;

internal class Example
{
    internal static void Main()
    {
        const string mutexName = "MutexExample4";

        Mutex m = null;
        bool doesNotExist = false;
        bool unauthorized = false;

        // The value of this variable is set by the mutex
        // constructor. It is true if the named system mutex was
        // created, and false if the named mutex already existed.
        //
        bool mutexWasCreated = false;

        // Attempt to open the named mutex.
        try
        {
            // Open the mutex with (MutexRights.Synchronize |
            // MutexRights.Modify), to enter and release the
            // named mutex.
            //
            m = Mutex.OpenExisting(mutexName);
        }
        catch(WaitHandleCannotBeOpenedException)
        {
            Console.WriteLine("Mutex does not exist.");
            doesNotExist = true;
        }
        catch(UnauthorizedAccessException ex)
        {
            Console.WriteLine("Unauthorized access: {0}", ex.Message);
            unauthorized = true;
        }

        // There are three cases: (1) The mutex does not exist.
        // (2) The mutex exists, but the current user doesn't 
        // have access. (3) The mutex exists and the user has
        // access.
        //
        if (doesNotExist)
        {
            // The mutex does not exist, so create it.

            // Create an access control list (ACL) that denies the
            // current user the right to enter or release the 
            // mutex, but allows the right to read and change
            // security information for the mutex.
            //
            string user = Environment.UserDomainName + "\\"
                + Environment.UserName;
            var mSec = new MutexSecurity();

            MutexAccessRule rule = new MutexAccessRule(user, 
                MutexRights.Synchronize | MutexRights.Modify, 
                AccessControlType.Deny);
            mSec.AddAccessRule(rule);

            rule = new MutexAccessRule(user, 
                MutexRights.ReadPermissions | MutexRights.ChangePermissions,
                AccessControlType.Allow);
            mSec.AddAccessRule(rule);

            // Create a Mutex object that represents the system
            // mutex named by the constant 'mutexName', with
            // initial ownership for this thread, and with the
            // specified security access. The Boolean value that 
            // indicates creation of the underlying system object
            // is placed in mutexWasCreated.
            //
            m = new Mutex(true, mutexName, out mutexWasCreated, mSec);

            // If the named system mutex was created, it can be
            // used by the current instance of this program, even 
            // though the current user is denied access. The current
            // program owns the mutex. Otherwise, exit the program.
            // 
            if (mutexWasCreated)
            {
                Console.WriteLine("Created the mutex.");
            }
            else
            {
                Console.WriteLine("Unable to create the mutex.");
                return;
            }
        }
        else if (unauthorized)
        {
            // Open the mutex to read and change the access control
            // security. The access control security defined above
            // allows the current user to do this.
            //
            try
            {
                m = Mutex.OpenExisting(mutexName, 
                    MutexRights.ReadPermissions | MutexRights.ChangePermissions);

                // Get the current ACL. This requires 
                // MutexRights.ReadPermissions.
                MutexSecurity mSec = m.GetAccessControl();
                
                string user = Environment.UserDomainName + "\\"
                    + Environment.UserName;

                // First, the rule that denied the current user 
                // the right to enter and release the mutex must
                // be removed.
                MutexAccessRule rule = new MutexAccessRule(user, 
                     MutexRights.Synchronize | MutexRights.Modify,
                     AccessControlType.Deny);
                mSec.RemoveAccessRule(rule);

                // Now grant the user the correct rights.
                // 
                rule = new MutexAccessRule(user, 
                    MutexRights.Synchronize | MutexRights.Modify,
                    AccessControlType.Allow);
                mSec.AddAccessRule(rule);

                // Update the ACL. This requires
                // MutexRights.ChangePermissions.
                m.SetAccessControl(mSec);

                Console.WriteLine("Updated mutex security.");

                // Open the mutex with (MutexRights.Synchronize 
                // | MutexRights.Modify), the rights required to
                // enter and release the mutex.
                //
                m = Mutex.OpenExisting(mutexName);
            }
            catch(UnauthorizedAccessException ex)
            {
                Console.WriteLine("Unable to change permissions: {0}",
                    ex.Message);
                return;
            }
        }

        // If this program created the mutex, it already owns
        // the mutex.
        //
        if (!mutexWasCreated)
        {
            // Enter the mutex, and hold it until the program
            // exits.
            //
            try
            {
                Console.WriteLine("Wait for the mutex.");
                m.WaitOne();
                Console.WriteLine("Entered the mutex.");
            }
            catch(UnauthorizedAccessException ex)
            {
                Console.WriteLine("Unauthorized access: {0}", ex.Message);
            }
        }

        Console.WriteLine("Press the Enter key to exit.");
        Console.ReadLine();
        m.ReleaseMutex();
        m.Dispose();
    }
}
Imports System.Threading
Imports System.Security.AccessControl

Friend Class Example

    <MTAThread> _
    Friend Shared Sub Main()
        Const mutexName As String = "MutexExample4"

        Dim m As Mutex = Nothing
        Dim doesNotExist as Boolean = False
        Dim unauthorized As Boolean = False

        ' The value of this variable is set by the mutex
        ' constructor. It is True if the named system mutex was
        ' created, and False if the named mutex already existed.
        '
        Dim mutexWasCreated As Boolean

        ' Attempt to open the named mutex.
        Try
            ' Open the mutex with (MutexRights.Synchronize Or
            ' MutexRights.Modify), to enter and release the
            ' named mutex.
            '
            m = Mutex.OpenExisting(mutexName)
        Catch ex As WaitHandleCannotBeOpenedException
            Console.WriteLine("Mutex does not exist.")
            doesNotExist = True
        Catch ex As UnauthorizedAccessException
            Console.WriteLine("Unauthorized access: {0}", ex.Message)
            unauthorized = True
        End Try

        ' There are three cases: (1) The mutex does not exist.
        ' (2) The mutex exists, but the current user doesn't 
        ' have access. (3) The mutex exists and the user has
        ' access.
        '
        If doesNotExist Then
            ' The mutex does not exist, so create it.

            ' Create an access control list (ACL) that denies the
            ' current user the right to enter or release the 
            ' mutex, but allows the right to read and change
            ' security information for the mutex.
            '
            Dim user As String = Environment.UserDomainName _ 
                & "\" & Environment.UserName
            Dim mSec As New MutexSecurity()

            Dim rule As New MutexAccessRule(user, _
                MutexRights.Synchronize Or MutexRights.Modify, _
                AccessControlType.Deny)
            mSec.AddAccessRule(rule)

            rule = New MutexAccessRule(user, _
                MutexRights.ReadPermissions Or _
                MutexRights.ChangePermissions, _
                AccessControlType.Allow)
            mSec.AddAccessRule(rule)

            ' Create a Mutex object that represents the system
            ' mutex named by the constant 'mutexName', with
            ' initial ownership for this thread, and with the
            ' specified security access. The Boolean value that 
            ' indicates creation of the underlying system object
            ' is placed in mutexWasCreated.
            '
            m = New Mutex(True, mutexName, mutexWasCreated, mSec)

            ' If the named system mutex was created, it can be
            ' used by the current instance of this program, even 
            ' though the current user is denied access. The current
            ' program owns the mutex. Otherwise, exit the program.
            ' 
            If mutexWasCreated Then
                Console.WriteLine("Created the mutex.")
            Else
                Console.WriteLine("Unable to create the mutex.")
                Return
            End If

        ElseIf unauthorized Then

            ' Open the mutex to read and change the access control
            ' security. The access control security defined above
            ' allows the current user to do this.
            '
            Try
                m = Mutex.OpenExisting(mutexName, _
                    MutexRights.ReadPermissions Or _
                    MutexRights.ChangePermissions)

                ' Get the current ACL. This requires 
                ' MutexRights.ReadPermissions.
                Dim mSec As MutexSecurity = m.GetAccessControl()
                
                Dim user As String = Environment.UserDomainName _ 
                    & "\" & Environment.UserName

                ' First, the rule that denied the current user 
                ' the right to enter and release the mutex must
                ' be removed.
                Dim rule As New MutexAccessRule(user, _
                    MutexRights.Synchronize Or MutexRights.Modify, _
                    AccessControlType.Deny)
                mSec.RemoveAccessRule(rule)

                ' Now grant the user the correct rights.
                ' 
                rule = New MutexAccessRule(user, _
                    MutexRights.Synchronize Or MutexRights.Modify, _
                    AccessControlType.Allow)
                mSec.AddAccessRule(rule)

                ' Update the ACL. This requires
                ' MutexRights.ChangePermissions.
                m.SetAccessControl(mSec)

                Console.WriteLine("Updated mutex security.")

                ' Open the mutex with (MutexRights.Synchronize 
                ' Or MutexRights.Modify), the rights required to
                ' enter and release the mutex.
                '
                m = Mutex.OpenExisting(mutexName)

            Catch ex As UnauthorizedAccessException
                Console.WriteLine("Unable to change permissions: {0}", _
                    ex.Message)
                Return
            End Try

        End If

        ' If this program created the mutex, it already owns
        ' the mutex.
        '
        If Not mutexWasCreated Then
            ' Enter the mutex, and hold it until the program
            ' exits.
            '
            Try
                Console.WriteLine("Wait for the mutex.")
                m.WaitOne()
                Console.WriteLine("Entered the mutex.")
            Catch ex As UnauthorizedAccessException
                Console.WriteLine("Unauthorized access: {0}", _
                    ex.Message)
            End Try
        End If

        Console.WriteLine("Press the Enter key to exit.")
        Console.ReadLine()
        m.ReleaseMutex()
        m.Dispose()
    End Sub 
End Class

Poznámky

Může name mít předponu Global\ nebo Local\ zadat obor názvů. Global Po zadání oboru názvů může být synchronizační objekt sdílen se všemi procesy v systému. Local Pokud je zadán obor názvů, což je také výchozí, pokud není zadán žádný obor názvů, synchronizační objekt může být sdílen s procesy ve stejné relaci. Na Windows je relace relace přihlášení a služby se obvykle spouští v jiné neinteraktivní relaci. V operačních systémech Unix má každé prostředí vlastní relaci. Objekty místní synchronizace relace můžou být vhodné pro synchronizaci mezi procesy s vztahem nadřazenosti nebo podřízenosti, kde se všechny spouští ve stejné relaci. Další informace o názvech synchronizačních objektů v Windows najdete v tématu Názvové objektyobjektu.

name Pokud je zadána a synchronizační objekt požadovaného typu již v oboru názvů existuje, použije se existující objekt synchronizace. Pokud synchronizační objekt jiného typu již v oboru názvů existuje, WaitHandleCannotBeOpenedException vyvolá se vyvolá. V opačném případě se vytvoří nový synchronizační objekt.

Pokud name není null a initiallyOwned je true, volající vlákno vlastní pojmenovaný mutex pouze v případě, že createdNew je true po volání. Jinak vlákno může požádat mutex voláním WaitOne metody.

Tento konstruktor použijte k použití zabezpečení řízení přístupu na pojmenovaný systémový mutex při jeho vytvoření, což brání jinému kódu v převzetí kontroly mutex.

Tento konstruktor inicializuje Mutex objekt, který představuje pojmenovaný systémový mutex. Můžete vytvořit více Mutex objektů, které představují stejný pojmenovaný systémový mutex.

Pokud pojmenovaný systémový mutex neexistuje, vytvoří se se zadaným zabezpečením řízení přístupu. Pokud pojmenovaný mutex existuje, zadané zabezpečení řízení přístupu se ignoruje.

Note

Volající má plnou kontrolu nad nově vytvořeným Mutex objektem, i když mutexSecurity odmítne nebo neudělí aktuálnímu uživateli přístupová práva. Pokud se ale aktuální uživatel pokusí získat jiný objekt Mutex představující stejný pojmenovaný mutex pomocí konstruktoru nebo metody OpenExisting, použije se Windows zabezpečení řízení přístupu.

Pokud již byl pojmenovaný mutex vytvořen se zabezpečením řízení přístupu a volající nemá MutexRights.FullControl, vyvolá se výjimka. Pokud chcete otevřít existující pojmenovaný mutex pouze s těmito oprávněními potřebnými pro synchronizaci aktivit vlákna, přečtěte si tuto metodu OpenExisting .

Pokud zadáte null nebo prázdný řetězec pro name, vytvoří se místní mutex, jako byste volali Mutex(Boolean) konstruktor. V tomto případě je createdNew vždy true.

Vzhledem k tomu, že se jedná o systémové, pojmenované mutexy lze použít ke koordinaci využití prostředků napříč hranicemi procesu.

Note

Na serveru se spuštěnou terminálovou službou může pojmenovaný systémový mutex mít dvě úrovně viditelnosti. Pokud název začíná předponou Global\, je mutex viditelný ve všech relacích terminálového serveru. Pokud jeho název začíná předponou Local\, je mutex viditelný pouze v relaci terminálového serveru, kde byla vytvořena. V takovém případě může existovat samostatný mutex se stejným názvem v každé druhé relaci terminálového serveru na serveru. Pokud při vytváření pojmenovaného mutex nezadáte předponu, převezme předponu Local\. V rámci relace terminálového serveru jsou dva mutexy, jejichž názvy se liší pouze podle jejich předpon, samostatné mutexy a oba jsou viditelné pro všechny procesy v relaci terminálového serveru. To znamená, že názvy Global\ předpon a Local\ popisují rozsah názvu mutex vzhledem k relacím terminálového serveru, nikoli vzhledem k procesům.

Caution

Ve výchozím nastavení není pojmenovaný mutex omezen na uživatele, který ho vytvořil. Ostatní uživatelé mohou být schopni otevřít a používat mutex, včetně zasahování do mutexu zadáním mutexu a jeho ukončením. Chcete-li omezit přístup na konkrétní uživatele, můžete MutexSecurity předat při vytváření pojmenovaného mutex. Vyhněte se používání pojmenovaných mutexů bez omezení přístupu v systémech, které můžou mít nedůvěryhodné uživatele se spuštěným kódem.

Zpětné lomítko (\) je vyhrazený znak v názvu mutex. Nepoužívejte zpětné lomítko (\) v názvu mutex s výjimkou toho, jak je uvedeno v poznámce při použití mutexů v relacích terminálového serveru. DirectoryNotFoundException Jinak může dojít k vyvolání, i když název mutex představuje existující soubor.

Platí pro

Mutex(Boolean, String, NamedWaitHandleOptions, Boolean)

Zdroj:
Mutex.cs
Zdroj:
Mutex.cs

Inicializuje novou instanci Mutex třídy s logickou hodnotou, která označuje, zda volající vlákno by mělo mít počáteční vlastnictví mutex, řetězec, který je název mutex, možnosti nastavit uživatelský obor a relace-obor přístupu, a logickou hodnotu, která, když metoda vrátí, označuje, zda volající vlákno bylo uděleno počáteční vlastnictví mutex.

public:
 Mutex(bool initiallyOwned, System::String ^ name, System::Threading::NamedWaitHandleOptions options, [Runtime::InteropServices::Out] bool % createdNew);
public Mutex(bool initiallyOwned, string? name, System.Threading.NamedWaitHandleOptions options, out bool createdNew);
new System.Threading.Mutex : bool * string * System.Threading.NamedWaitHandleOptions * bool -> System.Threading.Mutex
Public Sub New (initiallyOwned As Boolean, name As String, options As NamedWaitHandleOptions, ByRef createdNew As Boolean)

Parametry

initiallyOwned
Boolean

trueposkytnout volající vlákno počáteční vlastnictví pojmenovaného systému mutex pokud pojmenovaný systém mutex je vytvořen v důsledku tohoto volání; v opačném případě . false

name
String

Název, pokud je synchronizační objekt sdílen s jinými procesy; null v opačném případě nebo prázdný řetězec. V názvu se rozlišují malá a velká písmena.

options
NamedWaitHandleOptions

Možnosti oboru pojmenovaného systémového mutexu. Ve výchozím nastavení je přístup omezený pouze na aktuálního uživatele a aktuální relaci. Zadané možnosti můžou mít vliv na obor názvů pro název a přístup k podkladovému systémovému objektu mutex.

createdNew
Boolean

Pokud tato metoda vrátí, obsahuje logickou hodnotu, která je true v případě, že byl vytvořen místní mutex (tj. pokud name je null nebo prázdný řetězec) nebo pokud zadaný pojmenovaný systémový mutex byl vytvořen; obsahuje false , pokud zadaný pojmenovaný systémový mutex již existoval. Tento parametr se předává neinicializovaný.

Výjimky

Pojmenovaný mutex existuje a má zabezpečení řízení přístupu, ale uživatel nemá FullControl.

name je neplatný. Může to být z různých důvodů, včetně některých omezení, která může operační systém umístit, například neznámé předpony nebo neplatné znaky. Všimněte si, že název a běžné předpony "Global\" a "Local\" rozlišují malá a velká písmena.

nebo

Došlo k nějaké jiné chybě. Vlastnost HResult může poskytnout další informace.

pouze Windows: name zadal neznámý obor názvů. Další informace najdete v tématu Názvy objektů .

name je příliš dlouhý. Omezení délky můžou záviset na operačním systému nebo konfiguraci.

Synchronizační objekt se zadaným objektem name nelze vytvořit. Synchronizační objekt jiného typu může mít stejný název. nebo

Objekt se zadaným name objektem existuje, ale zadaný options objekt není kompatibilní s možnostmi existujícího objektu.

Poznámky

name Pokud je zadán a synchronizační objekt požadovaného typu již v oboru názvů existuje, použije se existující synchronizační objekt, pokud options však určuje přístup omezený na aktuálního uživatele a synchronizační objekt není s ním kompatibilní, WaitHandleCannotBeOpenedException vyvolá se. Pokud synchronizační objekt jiného typu již v oboru názvů existuje, WaitHandleCannotBeOpenedException vyvolá se i objekt synchronizace. V opačném případě se vytvoří nový synchronizační objekt.

Pokud name není null a initiallyOwned je true, volající vlákno vlastní pojmenovaný mutex pouze v případě, že createdNew je true po volání. Jinak vlákno může požádat mutex voláním WaitOne metody.

Tento konstruktor inicializuje Mutex objekt, který představuje pojmenovaný systémový mutex. Můžete vytvořit více Mutex objektů, které představují stejný pojmenovaný systémový mutex.

Pokud již byl pojmenovaný mutex vytvořen se zabezpečením řízení přístupu a volající nemá MutexRights.FullControl práva, vyvolá se výjimka. Pokud chcete otevřít existující pojmenovaný mutex pouze s těmito oprávněními potřebnými pro synchronizaci aktivit vlákna, přečtěte si tuto metodu OpenExisting .

Pokud zadáte null nebo prázdný řetězec pro name, vytvoří se místní mutex, jako byste volali Mutex(Boolean) konstruktor. V tomto případě je createdNew vždy true.

Vzhledem k tomu, že se jedná o systémové, pojmenované mutexy lze použít ke koordinaci využití prostředků napříč hranicemi procesu.

Parametr options lze zadat tak, aby určil, jestli je pojmenovaný mutex přístupný pouze aktuálnímu uživateli nebo všem uživatelům. Umožňuje také určit, zda je pojmenovaný mutex přístupný pro procesy pouze v aktuální relaci nebo pro všechny relace. Další informace najdete na webu NamedWaitHandleOptions.

Viz také

Platí pro