Mutex Constructeurs

Définition

Initialise une nouvelle instance de la classe Mutex.

Surcharges

Nom Description
Mutex()

Initialise une nouvelle instance de la Mutex classe avec des propriétés par défaut.

Mutex(Boolean)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex.

Mutex(Boolean, String)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex et une chaîne qui est le nom du mutex.

Mutex(String, NamedWaitHandleOptions)

Initialise une nouvelle instance de la Mutex classe avec une chaîne qui est le nom du mutex et des options permettant de définir l’étendue utilisateur et l’accès à l’étendue de session. Le thread appelant ne demande pas d’avoir la propriété initiale du mutex.

Mutex(Boolean, String, Boolean)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex et une valeur booléenne qui, lorsque la méthode retourne, indique si le thread appelant a reçu la propriété initiale du mutex.

Mutex(Boolean, String, NamedWaitHandleOptions)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex et les options permettant de définir l’accès à l’étendue utilisateur et à l’étendue de session.

Mutex(Boolean, String, Boolean, MutexSecurity)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex, une variable booléenne qui, lorsque la méthode retourne, indique si le thread appelant a reçu la propriété initiale du mutex et la sécurité du contrôle d’accès à appliquer au mutex nommé.

Mutex(Boolean, String, NamedWaitHandleOptions, Boolean)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex, des options permettant de définir l’étendue utilisateur et l’accès à l’étendue de session et une valeur booléenne qui, lorsque la méthode retourne, indique si le thread appelant a reçu la propriété initiale du mutex.

Mutex()

Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec des propriétés par défaut.

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

Exemples

L’exemple de code suivant montre comment un objet local Mutex est utilisé pour synchroniser l’accès à une ressource protégée. Le thread qui crée le mutex ne le possède pas initialement.

// 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

Remarques

L’appel de cette surcharge de constructeur est identique à l’appel de la Mutex(Boolean) surcharge du constructeur et en spécifiant false la propriété initiale du mutex. Autrement dit, le thread appelant ne possède pas le mutex.

Voir aussi

S’applique à

Mutex(Boolean)

Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex.

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

Paramètres

initiallyOwned
Boolean

true pour donner à l’appel la propriété initiale du thread appelant du mutex ; sinon, false.

Exemples

L’exemple de code suivant montre comment un objet local Mutex est utilisé pour synchroniser l’accès à une ressource protégée. Thread qui crée le Mutex propriétaire initialement.

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

Voir aussi

S’applique à

Mutex(Boolean, String)

Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex et une chaîne qui est le nom du 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)

Paramètres

initiallyOwned
Boolean

true pour donner à l’appel la propriété initiale du thread appelant du mutex système nommé si le mutex système nommé est créé à la suite de cet appel ; sinon, false.

name
String

Nom, si l’objet de synchronisation doit être partagé avec d’autres processus ; sinon, null ou une chaîne vide. Le nom respecte la casse. La barre oblique inverse (\) est réservée et peut uniquement être utilisée pour spécifier un espace de noms. Pour plus d’informations sur les espaces de noms, consultez la section remarques. Il peut y avoir d’autres restrictions sur le nom en fonction du système d’exploitation. Par exemple, sur les systèmes d’exploitation Unix, le nom après l’exclusion de l’espace de noms doit être un nom de fichier valide.

Attributs

Exceptions

Le mutex nommé existe et dispose d’une sécurité de contrôle d’accès, mais l’utilisateur n’a FullControlpas .

name n’est pas valide. Cela peut être pour diverses raisons, notamment certaines restrictions qui peuvent être placées par le système d’exploitation, telles qu’un préfixe inconnu ou des caractères non valides. Notez que le nom et les préfixes communs « Global\ » et « Local\ » respectent la casse.

- ou -

Il y a eu une autre erreur. La HResult propriété peut fournir plus d’informations.

Windows uniquement : name spécifié un espace de noms inconnu. Pour plus d’informations, consultez Noms d’objets .

name est trop long. Les restrictions de longueur peuvent dépendre du système d’exploitation ou de la configuration.

Impossible de créer un objet de synchronisation avec l’objet fourni name . Un objet de synchronisation d’un type différent peut avoir le même nom.

.NET Framework uniquement : name est plus long que MAX_PATH (260 caractères).

Exemples

L’exemple suivant montre comment un mutex nommé est utilisé pour signaler entre les threads s’exécutant dans deux processus distincts.

Exécutez ce programme à partir de deux fenêtres de commande ou plus. Chaque processus crée un Mutex objet qui représente le mutex MyMutexnommé . Le mutex nommé est un objet système dont la durée de vie est limitée par les durées de vie des Mutex objets qui le représentent. Le mutex nommé est créé lorsque le premier processus crée son Mutex objet ; dans cet exemple, le mutex nommé appartient au premier processus qui exécute le programme. Le mutex nommé est détruit lorsque tous les Mutex objets qui le représentent ont été libérés.

La surcharge du constructeur utilisée dans cet exemple ne peut pas indiquer au thread appelant si la propriété initiale du mutex nommé a été accordée. Vous ne devez pas utiliser ce constructeur pour demander la propriété initiale, sauf si vous pouvez être certain que le thread crée le mutex nommé.

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

Remarques

Il name peut être préfixé Global\ ou Local\ spécifier un espace de noms. Lorsque l’espace Global de noms est spécifié, l’objet de synchronisation peut être partagé avec tous les processus sur le système. Lorsque l’espace Local de noms est spécifié, qui est également la valeur par défaut lorsqu’aucun espace de noms n’est spécifié, l’objet de synchronisation peut être partagé avec des processus dans la même session. Sur Windows, une session est une session de connexion, et les services s’exécutent généralement dans une autre session non interactive. Sur les systèmes d’exploitation de type Unix, chaque interpréteur de commandes a sa propre session. Les objets de synchronisation locale de session peuvent être appropriés pour la synchronisation entre les processus avec une relation parent/enfant où ils s’exécutent tous dans la même session. Pour plus d’informations sur les noms d’objets de synchronisation sur Windows, consultez Object Names.

Si un name objet de synchronisation du type demandé existe déjà dans l’espace de noms, l’objet de synchronisation existant est utilisé. Si un objet de synchronisation d’un type différent existe déjà dans l’espace de noms, un WaitHandleCannotBeOpenedException objet est levée. Sinon, un nouvel objet de synchronisation est créé.

Si name ce n’est pas null le cas, initiallyOwnedtruele thread appelant possède le mutex uniquement si le mutex système nommé a été créé à la suite de cet appel. Étant donné qu’il n’existe aucun mécanisme permettant de déterminer si le mutex système nommé a été créé, il est préférable de le spécifier falseinitiallyOwned lors de l’appel de cette surcharge de constructeur. Vous pouvez utiliser le Mutex(Boolean, String, Boolean) constructeur si vous devez déterminer la propriété initiale.

Ce constructeur initialise un Mutex objet qui représente un mutex système nommé. Vous pouvez créer plusieurs Mutex objets qui représentent le même mutex système nommé.

Si le mutex nommé a déjà été créé avec la sécurité du contrôle d’accès et que l’appelant n’a MutexRights.FullControlpas , une exception est levée. Pour ouvrir un mutex nommé existant avec uniquement les autorisations nécessaires à la synchronisation des activités de thread, consultez la OpenExisting méthode.

Si vous spécifiez null ou une chaîne vide pour name, un mutex local est créé, comme si vous aviez appelé le Mutex(Boolean) constructeur.

Étant donné qu’ils sont à l’échelle du système, les mutex nommés peuvent être utilisés pour coordonner l’utilisation des ressources au-delà des limites de processus.

Note

Sur un serveur exécutant les services Terminal Services, un mutex système nommé peut avoir deux niveaux de visibilité. Si son nom commence par le préfixe Global\, le mutex est visible dans toutes les sessions du serveur terminal. Si son nom commence par le préfixe Local\, le mutex est visible uniquement dans la session du serveur terminal où il a été créé. Dans ce cas, un mutex distinct portant le même nom peut exister dans chacune des autres sessions de serveur terminal sur le serveur. Si vous ne spécifiez pas de préfixe lorsque vous créez un mutex nommé, il prend le préfixe Local\. Dans une session de serveur terminal, deux mutex dont les noms diffèrent uniquement par leurs préfixes sont des mutex distincts, et les deux sont visibles par tous les processus de la session du serveur terminal. Autrement dit, les noms Global\ de préfixes et Local\ décrivent l’étendue du nom mutex par rapport aux sessions du serveur terminal, et non par rapport aux processus.

Avertissement

Par défaut, un mutex nommé n’est pas limité à l’utilisateur qui l’a créé. D’autres utilisateurs peuvent être en mesure d’ouvrir et d’utiliser le mutex, y compris interférer avec le mutex en entrant le mutex et en ne le quittant pas. Sur les systèmes d’exploitation de type Unix, le système de fichiers est utilisé dans l’implémentation de mutex nommés, et d’autres utilisateurs peuvent interférer avec les mutex nommés de manière plus significative. Sur Windows, pour restreindre l’accès à des utilisateurs spécifiques, vous pouvez utiliser une surcharge de constructeur ou MutexAcl et passer un MutexSecurity lors de la création du mutex nommé. Sur les systèmes d’exploitation de type Unix, il n’existe actuellement aucun moyen de restreindre l’accès à un mutex nommé. Évitez d’utiliser des mutex nommés sans restrictions d’accès sur les systèmes susceptibles d’avoir des utilisateurs non approuvés exécutant du code.

La barre oblique inverse (\) est un caractère réservé dans un nom mutex. N’utilisez pas de barre oblique inverse (\) dans un nom mutex, sauf spécifié dans la note sur l’utilisation de mutex dans les sessions de serveur terminal. Sinon, un DirectoryNotFoundException peut être levée, même si le nom du mutex représente un fichier existant.

Voir aussi

S’applique à

Mutex(String, NamedWaitHandleOptions)

Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec une chaîne qui est le nom du mutex et des options permettant de définir l’étendue utilisateur et l’accès à l’étendue de session. Le thread appelant ne demande pas d’avoir la propriété initiale du mutex.

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)

Paramètres

name
String

Nom, si l’objet de synchronisation doit être partagé avec d’autres processus ; sinon, null ou une chaîne vide. Le nom respecte la casse.

options
NamedWaitHandleOptions

Options d’étendue pour le mutex système nommé. Par défaut, l’accès est limité à l’utilisateur actuel et à la session active uniquement. Les options spécifiées peuvent affecter l’espace de noms pour le nom et l’accès à l’objet mutex système sous-jacent.

Exceptions

Le mutex nommé existe et dispose d’une sécurité de contrôle d’accès, mais l’utilisateur n’a FullControlpas .

name n’est pas valide. Cela peut être pour diverses raisons, notamment certaines restrictions qui peuvent être placées par le système d’exploitation, telles qu’un préfixe inconnu ou des caractères non valides. Notez que le nom et les préfixes communs « Global\ » et « Local\ » respectent la casse.

- ou -

Il y a eu une autre erreur. La HResult propriété peut fournir plus d’informations.

Windows uniquement : name spécifié un espace de noms inconnu. Pour plus d’informations, consultez Noms d’objets .

name est trop long. Les restrictions de longueur peuvent dépendre du système d’exploitation ou de la configuration.

Impossible de créer un objet de synchronisation avec l’objet fourni name . Un objet de synchronisation d’un type différent peut avoir le même nom. - ou -

Un objet avec l’objet spécifié name existe, mais les options options spécifiées ne sont pas compatibles avec les options de l’objet existant.

Remarques

Si un name objet de synchronisation est fourni et qu’un objet de synchronisation du type demandé existe déjà dans l’espace de noms, l’objet de synchronisation existant est utilisé. Toutefois, si options l’accès est limité à l’utilisateur actuel et que l’objet de synchronisation n’est pas compatible avec celui-ci, un WaitHandleCannotBeOpenedException objet de synchronisation est levée. Si un objet de synchronisation d’un type différent existe déjà dans l’espace de noms, un WaitHandleCannotBeOpenedException objet est également levée. Sinon, un nouvel objet de synchronisation est créé.

Ce constructeur initialise un Mutex objet qui représente un mutex système nommé. Vous pouvez créer plusieurs Mutex objets qui représentent le même mutex système nommé.

Si le mutex nommé a déjà été créé avec la sécurité du contrôle d’accès et que l’appelant n’a MutexRights.FullControlpas , une exception est levée. Pour ouvrir un mutex nommé existant avec uniquement les autorisations nécessaires à la synchronisation des activités de thread, consultez la OpenExisting méthode.

Si vous spécifiez null ou une chaîne vide pour name, un mutex local est créé, comme si vous aviez appelé le Mutex(Boolean) constructeur.

Étant donné qu’ils sont à l’échelle du système, les mutex nommés peuvent être utilisés pour coordonner l’utilisation des ressources au-delà des limites de processus.

Le options paramètre peut être fourni pour spécifier si le mutex nommé est accessible uniquement à l’utilisateur actuel ou à tous les utilisateurs. Il vous permet également de spécifier si le mutex nommé est accessible aux processus de la session active uniquement ou à toutes les sessions. Pour plus d’informations, consultez NamedWaitHandleOptions.

La barre oblique inverse (\) est un caractère réservé dans un nom mutex. N’utilisez pas de barre oblique inverse (\) dans un nom mutex, sauf spécifié dans la note sur l’utilisation de mutex dans les sessions de serveur terminal. Sinon, un DirectoryNotFoundException peut être levée, même si le nom du mutex représente un fichier existant.

Voir aussi

S’applique à

Mutex(Boolean, String, Boolean)

Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex et une valeur booléenne qui, lorsque la méthode retourne, indique si le thread appelant a reçu la propriété initiale du 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)

Paramètres

initiallyOwned
Boolean

true pour donner à l’appel la propriété initiale du thread appelant du mutex système nommé si le mutex système nommé est créé à la suite de cet appel ; sinon, false.

name
String

Nom, si l’objet de synchronisation doit être partagé avec d’autres processus ; sinon, null ou une chaîne vide. Le nom respecte la casse. La barre oblique inverse (\) est réservée et peut uniquement être utilisée pour spécifier un espace de noms. Pour plus d’informations sur les espaces de noms, consultez la section remarques. Il peut y avoir d’autres restrictions sur le nom en fonction du système d’exploitation. Par exemple, sur les systèmes d’exploitation Unix, le nom après l’exclusion de l’espace de noms doit être un nom de fichier valide.

createdNew
Boolean

Lorsque cette méthode est retournée, contient une valeur booléenne qui est true si un mutex local a été créé (autrement dit, s’il name s’agit null d’une chaîne vide) ou si le mutex système nommé spécifié a été créé ; false si le mutex système nommé spécifié existait déjà. Ce paramètre est passé non initialisé.

Attributs

Exceptions

Le mutex nommé existe et dispose d’une sécurité de contrôle d’accès, mais l’utilisateur n’a FullControlpas .

name n’est pas valide. Cela peut être pour diverses raisons, notamment certaines restrictions qui peuvent être placées par le système d’exploitation, telles qu’un préfixe inconnu ou des caractères non valides. Notez que le nom et les préfixes communs « Global\ » et « Local\ » respectent la casse.

- ou -

Il y a eu une autre erreur. La HResult propriété peut fournir plus d’informations.

Windows uniquement : name spécifié un espace de noms inconnu. Pour plus d’informations, consultez Noms d’objets .

name est trop long. Les restrictions de longueur peuvent dépendre du système d’exploitation ou de la configuration.

Impossible de créer un objet de synchronisation avec l’objet fourni name . Un objet de synchronisation d’un type différent peut avoir le même nom.

.NET Framework uniquement : name est plus long que MAX_PATH (260 caractères).

Exemples

L’exemple de code suivant montre comment un mutex nommé est utilisé pour signaler entre les processus ou les threads. Exécutez ce programme à partir de deux fenêtres de commande ou plus. Chaque processus crée un Mutex objet qui représente le mutex nommé « MyMutex ». Le mutex nommé est un objet système. Dans cet exemple, sa durée de vie est limitée par les durées de vie des Mutex objets qui le représentent. Le mutex nommé est créé lorsque le premier processus crée son objet local Mutex et détruit lorsque tous les Mutex objets qui le représentent ont été libérés. Le mutex nommé appartient initialement au premier processus. Le deuxième processus et tous les processus suivants attendent que les processus antérieurs libèrent le mutex nommé.

// 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

Remarques

Il name peut être préfixé Global\ ou Local\ spécifier un espace de noms. Lorsque l’espace Global de noms est spécifié, l’objet de synchronisation peut être partagé avec tous les processus sur le système. Lorsque l’espace Local de noms est spécifié, qui est également la valeur par défaut lorsqu’aucun espace de noms n’est spécifié, l’objet de synchronisation peut être partagé avec des processus dans la même session. Sur Windows, une session est une session de connexion, et les services s’exécutent généralement dans une autre session non interactive. Sur les systèmes d’exploitation de type Unix, chaque interpréteur de commandes a sa propre session. Les objets de synchronisation locale de session peuvent être appropriés pour la synchronisation entre les processus avec une relation parent/enfant où ils s’exécutent tous dans la même session. Pour plus d’informations sur les noms d’objets de synchronisation sur Windows, consultez Object Names.

Si un name objet de synchronisation du type demandé existe déjà dans l’espace de noms, l’objet de synchronisation existant est utilisé. Si un objet de synchronisation d’un type différent existe déjà dans l’espace de noms, un WaitHandleCannotBeOpenedException objet est levée. Sinon, un nouvel objet de synchronisation est créé.

Si name ce n’est pas null le cas, initiallyOwnedtruele thread appelant possède le mutex nommé uniquement s’il createdNew se trouve true après l’appel. Sinon, le thread peut demander le mutex en appelant la WaitOne méthode.

Ce constructeur initialise un Mutex objet qui représente un mutex système nommé. Vous pouvez créer plusieurs Mutex objets qui représentent le même mutex système nommé.

Si le mutex nommé a déjà été créé avec la sécurité du contrôle d’accès et que l’appelant n’a MutexRights.FullControl pas de droits, une exception est levée. Pour ouvrir un mutex nommé existant avec uniquement les autorisations nécessaires à la synchronisation des activités de thread, consultez la OpenExisting méthode.

Si vous spécifiez null ou une chaîne vide pour name, un mutex local est créé, comme si vous aviez appelé le Mutex(Boolean) constructeur. Dans ce cas, createdNew c’est toujours true.

Étant donné qu’ils sont à l’échelle du système, les mutex nommés peuvent être utilisés pour coordonner l’utilisation des ressources au-delà des limites de processus.

Note

Sur un serveur exécutant les services Terminal Services, un mutex système nommé peut avoir deux niveaux de visibilité. Si son nom commence par le préfixe Global\, le mutex est visible dans toutes les sessions du serveur terminal. Si son nom commence par le préfixe Local\, le mutex est visible uniquement dans la session du serveur terminal où il a été créé. Dans ce cas, un mutex distinct portant le même nom peut exister dans chacune des autres sessions de serveur terminal sur le serveur. Si vous ne spécifiez pas de préfixe lorsque vous créez un mutex nommé, il prend le préfixe Local\. Dans une session de serveur terminal, deux mutex dont les noms diffèrent uniquement par leurs préfixes sont des mutex distincts, et les deux sont visibles par tous les processus de la session du serveur terminal. Autrement dit, les noms Global\ de préfixes et Local\ décrivent l’étendue du nom mutex par rapport aux sessions du serveur terminal, et non par rapport aux processus.

Avertissement

Par défaut, un mutex nommé n’est pas limité à l’utilisateur qui l’a créé. D’autres utilisateurs peuvent être en mesure d’ouvrir et d’utiliser le mutex, y compris interférer avec le mutex en entrant le mutex et en ne le quittant pas. Sur les systèmes d’exploitation de type Unix, le système de fichiers est utilisé dans l’implémentation de mutex nommés, et d’autres utilisateurs peuvent interférer avec les mutex nommés de manière plus significative. Sur Windows, pour restreindre l’accès à des utilisateurs spécifiques, vous pouvez utiliser une surcharge de constructeur ou MutexAcl et passer un MutexSecurity lors de la création du mutex nommé. Sur les systèmes d’exploitation de type Unix, il n’existe actuellement aucun moyen de restreindre l’accès à un mutex nommé. Évitez d’utiliser des mutex nommés sans restrictions d’accès sur les systèmes susceptibles d’avoir des utilisateurs non approuvés exécutant du code.

La barre oblique inverse (\) est un caractère réservé dans un nom mutex. N’utilisez pas de barre oblique inverse (\) dans un nom mutex, sauf spécifié dans la note sur l’utilisation de mutex dans les sessions de serveur terminal. Sinon, un DirectoryNotFoundException peut être levée, même si le nom du mutex représente un fichier existant.

Voir aussi

S’applique à

Mutex(Boolean, String, NamedWaitHandleOptions)

Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex et les options permettant de définir l’accès à l’étendue utilisateur et à l’étendue de session.

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)

Paramètres

initiallyOwned
Boolean

true pour donner à l’appel la propriété initiale du thread appelant du mutex système nommé si le mutex système nommé est créé à la suite de cet appel ; sinon, false.

name
String

Nom, si l’objet de synchronisation doit être partagé avec d’autres processus ; sinon, null ou une chaîne vide. Le nom respecte la casse.

options
NamedWaitHandleOptions

Options d’étendue pour le mutex système nommé. Par défaut, l’accès est limité à l’utilisateur actuel et à la session active uniquement. Les options spécifiées peuvent affecter l’espace de noms pour le nom et l’accès à l’objet mutex système sous-jacent.

Exceptions

Le mutex nommé existe et dispose d’une sécurité de contrôle d’accès, mais l’utilisateur n’a FullControlpas .

name n’est pas valide. Cela peut être pour diverses raisons, notamment certaines restrictions qui peuvent être placées par le système d’exploitation, telles qu’un préfixe inconnu ou des caractères non valides. Notez que le nom et les préfixes communs « Global\ » et « Local\ » respectent la casse.

- ou -

Il y a eu une autre erreur. La HResult propriété peut fournir plus d’informations.

Windows uniquement : name spécifié un espace de noms inconnu. Pour plus d’informations, consultez Noms d’objets .

name est trop long. Les restrictions de longueur peuvent dépendre du système d’exploitation ou de la configuration.

Impossible de créer un objet de synchronisation avec l’objet fourni name . Un objet de synchronisation d’un type différent peut avoir le même nom. - ou -

Un objet avec l’objet spécifié name existe, mais les options options spécifiées ne sont pas compatibles avec les options de l’objet existant.

Remarques

Si un name objet de synchronisation est fourni et qu’un objet de synchronisation du type demandé existe déjà dans l’espace de noms, l’objet de synchronisation existant est utilisé. Toutefois, si options l’accès est limité à l’utilisateur actuel et que l’objet de synchronisation n’est pas compatible avec celui-ci, un WaitHandleCannotBeOpenedException objet de synchronisation est levée. Si un objet de synchronisation d’un type différent existe déjà dans l’espace de noms, un WaitHandleCannotBeOpenedException objet est également levée. Sinon, un nouvel objet de synchronisation est créé.

Si name ce n’est pas null le cas, initiallyOwnedtruele thread appelant possède le mutex uniquement si le mutex système nommé a été créé à la suite de cet appel. Étant donné qu’il n’existe aucun mécanisme permettant de déterminer si le mutex système nommé a été créé, il est préférable de le spécifier falseinitiallyOwned lors de l’appel de cette surcharge de constructeur. Vous pouvez utiliser le Mutex(Boolean, String, Boolean) constructeur si vous devez déterminer la propriété initiale.

Ce constructeur initialise un Mutex objet qui représente un mutex système nommé. Vous pouvez créer plusieurs Mutex objets qui représentent le même mutex système nommé.

Si le mutex nommé a déjà été créé avec la sécurité du contrôle d’accès et que l’appelant n’a MutexRights.FullControlpas , une exception est levée. Pour ouvrir un mutex nommé existant avec uniquement les autorisations nécessaires à la synchronisation des activités de thread, consultez la OpenExisting méthode.

Si vous spécifiez null ou une chaîne vide pour name, un mutex local est créé, comme si vous aviez appelé le Mutex(Boolean) constructeur.

Étant donné qu’ils sont à l’échelle du système, les mutex nommés peuvent être utilisés pour coordonner l’utilisation des ressources au-delà des limites de processus.

Le options paramètre peut être fourni pour spécifier si le mutex nommé est accessible uniquement à l’utilisateur actuel ou à tous les utilisateurs. Il vous permet également de spécifier si le mutex nommé est accessible aux processus de la session active uniquement ou à toutes les sessions. Pour plus d’informations, consultez NamedWaitHandleOptions.

Voir aussi

S’applique à

Mutex(Boolean, String, Boolean, MutexSecurity)

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex, une variable booléenne qui, lorsque la méthode retourne, indique si le thread appelant a reçu la propriété initiale du mutex et la sécurité du contrôle d’accès à appliquer au mutex nommé.

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)

Paramètres

initiallyOwned
Boolean

true pour donner à l’appel la propriété initiale du thread appelant du mutex système nommé si le mutex système nommé est créé à la suite de cet appel ; sinon, false.

name
String

Nom, si l’objet de synchronisation doit être partagé avec d’autres processus ; sinon, null ou une chaîne vide. Le nom respecte la casse. La barre oblique inverse (\) est réservée et peut uniquement être utilisée pour spécifier un espace de noms. Pour plus d’informations sur les espaces de noms, consultez la section remarques. Il peut y avoir d’autres restrictions sur le nom en fonction du système d’exploitation. Par exemple, sur les systèmes d’exploitation Unix, le nom après l’exclusion de l’espace de noms doit être un nom de fichier valide.

createdNew
Boolean

Lorsque cette méthode est retournée, contient une valeur booléenne qui est true si un mutex local a été créé (autrement dit, s’il name s’agit null d’une chaîne vide) ou si le mutex système nommé spécifié a été créé ; false si le mutex système nommé spécifié existait déjà. Ce paramètre est passé non initialisé.

mutexSecurity
MutexSecurity

Objet MutexSecurity qui représente la sécurité du contrôle d’accès à appliquer au mutex système nommé.

Attributs

Exceptions

name n’est pas valide. Cela peut être pour diverses raisons, notamment certaines restrictions qui peuvent être placées par le système d’exploitation, telles qu’un préfixe inconnu ou des caractères non valides. Notez que le nom et les préfixes communs « Global\ » et « Local\ » respectent la casse.

- ou -

Il y a eu une autre erreur. La HResult propriété peut fournir plus d’informations.

Windows uniquement : name spécifié un espace de noms inconnu. Pour plus d’informations, consultez Noms d’objets .

name est trop long. Les restrictions de longueur peuvent dépendre du système d’exploitation ou de la configuration.

Le mutex nommé existe et dispose d’une sécurité de contrôle d’accès, mais l’utilisateur n’a FullControlpas .

Impossible de créer un objet de synchronisation avec l’objet fourni name . Un objet de synchronisation d’un type différent peut avoir le même nom.

.NET Framework uniquement : name est plus long que MAX_PATH (260 caractères).

Exemples

L’exemple de code suivant illustre le comportement interprocesseur d’un mutex nommé avec la sécurité du contrôle d’accès. L’exemple utilise la OpenExisting(String) surcharge de méthode pour tester l’existence d’un mutex nommé.

Si le mutex n’existe pas, il est créé avec la sécurité de contrôle d’accès et de propriété initiale qui refuse à l’utilisateur actuel le droit d’utiliser le mutex, mais accorde le droit de lire et de modifier les autorisations sur le mutex.

Si vous exécutez l’exemple compilé à partir de deux fenêtres de commandes, la deuxième copie lève une exception de violation d’accès sur l’appel à OpenExisting(String). L’exception est interceptée et l’exemple utilise la OpenExisting(String, MutexRights) surcharge de méthode pour ouvrir le mutex avec les droits nécessaires pour lire et modifier les autorisations.

Une fois les autorisations modifiées, le mutex est ouvert avec les droits requis pour entrer et le libérer. Si vous exécutez l’exemple compilé à partir d’une troisième fenêtre de commande, il s’exécute à l’aide des nouvelles autorisations.

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

Remarques

Il name peut être préfixé Global\ ou Local\ spécifier un espace de noms. Lorsque l’espace Global de noms est spécifié, l’objet de synchronisation peut être partagé avec tous les processus sur le système. Lorsque l’espace Local de noms est spécifié, qui est également la valeur par défaut lorsqu’aucun espace de noms n’est spécifié, l’objet de synchronisation peut être partagé avec des processus dans la même session. Sur Windows, une session est une session de connexion, et les services s’exécutent généralement dans une autre session non interactive. Sur les systèmes d’exploitation de type Unix, chaque interpréteur de commandes a sa propre session. Les objets de synchronisation locale de session peuvent être appropriés pour la synchronisation entre les processus avec une relation parent/enfant où ils s’exécutent tous dans la même session. Pour plus d’informations sur les noms d’objets de synchronisation sur Windows, consultez Object Names.

Si un name objet de synchronisation du type demandé existe déjà dans l’espace de noms, l’objet de synchronisation existant est utilisé. Si un objet de synchronisation d’un type différent existe déjà dans l’espace de noms, un WaitHandleCannotBeOpenedException objet est levée. Sinon, un nouvel objet de synchronisation est créé.

Si name ce n’est pas null le cas, initiallyOwnedtruele thread appelant possède le mutex nommé uniquement s’il createdNew se trouve true après l’appel. Sinon, le thread peut demander le mutex en appelant la WaitOne méthode.

Utilisez ce constructeur pour appliquer la sécurité du contrôle d’accès à un mutex système nommé lorsqu’il est créé, ce qui empêche tout autre code de prendre le contrôle du mutex.

Ce constructeur initialise un Mutex objet qui représente un mutex système nommé. Vous pouvez créer plusieurs Mutex objets qui représentent le même mutex système nommé.

Si le mutex système nommé n’existe pas, il est créé avec la sécurité de contrôle d’accès spécifiée. Si le mutex nommé existe, la sécurité du contrôle d’accès spécifiée est ignorée.

Note

L’appelant a un contrôle total sur l’objet nouvellement créé Mutex , même s’il mutexSecurity refuse ou ne parvient pas à accorder des droits d’accès à l’utilisateur actuel. Toutefois, si l’utilisateur actuel tente d’obtenir un autre objet Mutex pour représenter le même mutex nommé, à l’aide d’un constructeur ou de la méthode OpenExisting, Windows sécurité du contrôle d’accès est appliquée.

Si le mutex nommé a déjà été créé avec la sécurité du contrôle d’accès et que l’appelant n’a MutexRights.FullControlpas , une exception est levée. Pour ouvrir un mutex nommé existant avec uniquement les autorisations nécessaires à la synchronisation des activités de thread, consultez la OpenExisting méthode.

Si vous spécifiez null ou une chaîne vide pour name, un mutex local est créé, comme si vous aviez appelé le Mutex(Boolean) constructeur. Dans ce cas, createdNew c’est toujours true.

Étant donné qu’ils sont à l’échelle du système, les mutex nommés peuvent être utilisés pour coordonner l’utilisation des ressources au-delà des limites de processus.

Note

Sur un serveur exécutant les services Terminal Services, un mutex système nommé peut avoir deux niveaux de visibilité. Si son nom commence par le préfixe Global\, le mutex est visible dans toutes les sessions du serveur terminal. Si son nom commence par le préfixe Local\, le mutex est visible uniquement dans la session du serveur terminal où il a été créé. Dans ce cas, un mutex distinct portant le même nom peut exister dans chacune des autres sessions de serveur terminal sur le serveur. Si vous ne spécifiez pas de préfixe lorsque vous créez un mutex nommé, il prend le préfixe Local\. Dans une session de serveur terminal, deux mutex dont les noms diffèrent uniquement par leurs préfixes sont des mutex distincts, et les deux sont visibles par tous les processus de la session du serveur terminal. Autrement dit, les noms Global\ de préfixes et Local\ décrivent l’étendue du nom mutex par rapport aux sessions du serveur terminal, et non par rapport aux processus.

Avertissement

Par défaut, un mutex nommé n’est pas limité à l’utilisateur qui l’a créé. D’autres utilisateurs peuvent être en mesure d’ouvrir et d’utiliser le mutex, y compris interférer avec le mutex en entrant le mutex et en ne le quittant pas. Pour restreindre l’accès à des utilisateurs spécifiques, vous pouvez passer un MutexSecurity message lors de la création du mutex nommé. Évitez d’utiliser des mutex nommés sans restrictions d’accès sur les systèmes susceptibles d’avoir des utilisateurs non approuvés exécutant du code.

La barre oblique inverse (\) est un caractère réservé dans un nom mutex. N’utilisez pas de barre oblique inverse (\) dans un nom mutex, sauf spécifié dans la note sur l’utilisation de mutex dans les sessions de serveur terminal. Sinon, un DirectoryNotFoundException peut être levée, même si le nom du mutex représente un fichier existant.

S’applique à

Mutex(Boolean, String, NamedWaitHandleOptions, Boolean)

Source:
Mutex.cs
Source:
Mutex.cs

Initialise une nouvelle instance de la Mutex classe avec une valeur booléenne qui indique si le thread appelant doit avoir la propriété initiale du mutex, une chaîne qui est le nom du mutex, des options permettant de définir l’étendue utilisateur et l’accès à l’étendue de session et une valeur booléenne qui, lorsque la méthode retourne, indique si le thread appelant a reçu la propriété initiale du 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)

Paramètres

initiallyOwned
Boolean

true pour donner à l’appel la propriété initiale du thread appelant du mutex système nommé si le mutex système nommé est créé à la suite de cet appel ; sinon, false.

name
String

Nom, si l’objet de synchronisation doit être partagé avec d’autres processus ; sinon, null ou une chaîne vide. Le nom respecte la casse.

options
NamedWaitHandleOptions

Options d’étendue pour le mutex système nommé. Par défaut, l’accès est limité à l’utilisateur actuel et à la session active uniquement. Les options spécifiées peuvent affecter l’espace de noms pour le nom et l’accès à l’objet mutex système sous-jacent.

createdNew
Boolean

Lorsque cette méthode est retournée, contient une valeur booléenne qui est true si un mutex local a été créé (autrement dit, s’il name s’agit null d’une chaîne vide) ou si le mutex système nommé spécifié a été créé ; contient false si le mutex système nommé spécifié existait déjà. Ce paramètre est passé non initialisé.

Exceptions

Le mutex nommé existe et dispose d’une sécurité de contrôle d’accès, mais l’utilisateur n’a FullControlpas .

name n’est pas valide. Cela peut être pour diverses raisons, notamment certaines restrictions qui peuvent être placées par le système d’exploitation, telles qu’un préfixe inconnu ou des caractères non valides. Notez que le nom et les préfixes communs « Global\ » et « Local\ » respectent la casse.

- ou -

Il y a eu une autre erreur. La HResult propriété peut fournir plus d’informations.

Windows uniquement : name spécifié un espace de noms inconnu. Pour plus d’informations, consultez Noms d’objets .

name est trop long. Les restrictions de longueur peuvent dépendre du système d’exploitation ou de la configuration.

Impossible de créer un objet de synchronisation avec l’objet fourni name . Un objet de synchronisation d’un type différent peut avoir le même nom. - ou -

Un objet avec l’objet spécifié name existe, mais les options options spécifiées ne sont pas compatibles avec les options de l’objet existant.

Remarques

Si un name objet de synchronisation est fourni et qu’un objet de synchronisation du type demandé existe déjà dans l’espace de noms, l’objet de synchronisation existant est utilisé. Toutefois, si options l’accès est limité à l’utilisateur actuel et que l’objet de synchronisation n’est pas compatible avec celui-ci, un WaitHandleCannotBeOpenedException objet de synchronisation est levée. Si un objet de synchronisation d’un type différent existe déjà dans l’espace de noms, un WaitHandleCannotBeOpenedException objet est également levée. Sinon, un nouvel objet de synchronisation est créé.

Si name ce n’est pas null le cas, initiallyOwnedtruele thread appelant possède le mutex nommé uniquement s’il createdNew se trouve true après l’appel. Sinon, le thread peut demander le mutex en appelant la WaitOne méthode.

Ce constructeur initialise un Mutex objet qui représente un mutex système nommé. Vous pouvez créer plusieurs Mutex objets qui représentent le même mutex système nommé.

Si le mutex nommé a déjà été créé avec la sécurité du contrôle d’accès et que l’appelant n’a MutexRights.FullControl pas de droits, une exception est levée. Pour ouvrir un mutex nommé existant avec uniquement les autorisations nécessaires à la synchronisation des activités de thread, consultez la OpenExisting méthode.

Si vous spécifiez null ou une chaîne vide pour name, un mutex local est créé, comme si vous aviez appelé le Mutex(Boolean) constructeur. Dans ce cas, createdNew c’est toujours true.

Étant donné qu’ils sont à l’échelle du système, les mutex nommés peuvent être utilisés pour coordonner l’utilisation des ressources au-delà des limites de processus.

Le options paramètre peut être fourni pour spécifier si le mutex nommé est accessible uniquement à l’utilisateur actuel ou à tous les utilisateurs. Il vous permet également de spécifier si le mutex nommé est accessible aux processus de la session active uniquement ou à toutes les sessions. Pour plus d’informations, consultez NamedWaitHandleOptions.

Voir aussi

S’applique à