Mutex Construtores

Definição

Inicializa uma nova instância da Mutex classe.

Sobrecargas

Name Description
Mutex()

Inicializa uma nova instância da Mutex classe com propriedades por defeito.

Mutex(Boolean)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread chamador deve ter a propriedade inicial do mutex.

Mutex(Boolean, String)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread que chama deve ter a propriedade inicial do mutex, e uma string que é o nome do mutex.

Mutex(String, NamedWaitHandleOptions)

Inicializa uma nova instância da Mutex classe com uma string que é o nome do mutex e opções para definir o acesso ao user-scope e session-scope. O fio de chamadas não solicita a posse inicial do mutex.

Mutex(Boolean, String, Boolean)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se a thread que chama deve ter a propriedade inicial do mutex, uma string que é o nome do mutex e um valor Booleano que, quando o método retorna, indica se a thread que chama recebeu a propriedade inicial do mutex.

Mutex(Boolean, String, NamedWaitHandleOptions)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread que chama deve ter propriedade inicial do mutex, uma string que é o nome do mutex e opções para definir o acesso ao âmbito do utilizador e ao âmbito da sessão.

Mutex(Boolean, String, Boolean, MutexSecurity)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se a thread chamadora deve ter propriedade inicial do mutex, uma string que é o nome do mutex, uma variável Booleana que, quando o método retorna, indica se a thread chamadora recebeu a propriedade inicial do mutex e a segurança de controlo de acesso a ser aplicada ao mutex nomeado.

Mutex(Boolean, String, NamedWaitHandleOptions, Boolean)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread que chama deve ter propriedade inicial do mutex, uma string que é o nome do mutex, opções para definir o acesso ao user-scope e session-scope, e um valor Booleano que, quando o método retorna, indica se o thread chamador recebeu a propriedade inicial do mutex.

Mutex()

Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com propriedades por defeito.

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

Exemplos

O seguinte exemplo de código mostra como um objeto local Mutex é usado para sincronizar o acesso a um recurso protegido. O thread que cria o mutex não o possui inicialmente.

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

Observações

Chamar a este construtor overload é o mesmo que chamar o Mutex(Boolean) construtor overload e especificar false a posse inicial do mutex. Ou seja, o tópico que chama não é dono do mutex.

Ver também

Aplica-se a

Mutex(Boolean)

Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread chamador deve ter a propriedade inicial do mutex.

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

Parâmetros

initiallyOwned
Boolean

true para dar ao fio chamador a propriedade inicial do mutex; caso contrário, false.

Exemplos

O seguinte exemplo de código mostra como um objeto local Mutex é usado para sincronizar o acesso a um recurso protegido. O fio que cria o Mutex é o proprietário inicialmente.

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

Ver também

Aplica-se a

Mutex(Boolean, String)

Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread que chama deve ter a propriedade inicial do mutex, e uma string que é o nome do 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)

Parâmetros

initiallyOwned
Boolean

true para dar ao thread que chama a propriedade inicial do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado desta chamada; caso contrário, false.

name
String

O nome, se o objeto de sincronização for partilhado com outros processos; caso contrário, null ou uma cadeia vazia. O nome é sensível a maiúsculas e minúsculas. O carácter de barra inversa (\) é reservado e só pode ser usado para especificar um namespace. Para mais informações sobre namespaces, consulte a secção de observações. Podem existir restrições adicionais quanto ao nome, dependendo do sistema operativo. Por exemplo, em sistemas operativos baseados em Unix, o nome após excluir o espaço de nomes deve ser um nome de ficheiro válido.

Atributos

Exceções

O mutex nomeado existe e tem segurança de controlo de acesso, mas o utilizador não tem FullControl.

name é inválido. Isto pode dever-se a várias razões, incluindo algumas restrições que podem ser impostas pelo sistema operativo, como um prefixo desconhecido ou caracteres inválidos. Note que o nome e os prefixos comuns "Global\" e "Local\" são sensíveis a maiúsculas minúsculas.

-ou-

Houve outro erro. A HResult propriedade pode fornecer mais informações.

Windows apenas: name especificava um namespace desconhecido. Consulte Nomes dos Objetos para mais informações.

O name é demasiado longo. As restrições de comprimento podem depender do sistema operativo ou da configuração.

Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de outro tipo pode ter o mesmo nome.

.NET Framework apenas: name é mais longo que MAX_PATH (260 caracteres).

Exemplos

O exemplo seguinte mostra como um mutex nomeado é usado para sinalizar entre threads a correr em dois processos separados.

Executa este programa a partir de duas ou mais janelas de comandos. Cada processo cria um Mutex objeto que representa o mutex MyMutexnomeado . O mutex nomeado é um objeto do sistema cujo tempo de vida é limitado pelos tempos de vida dos Mutex objetos que o representam. O mutex nomeado é criado quando o primeiro processo cria o seu Mutex objeto; neste exemplo, o mutex nomeado pertence ao primeiro processo que executa o programa. O mutex nomeado é destruído quando todos os Mutex objetos que o representam são libertados.

A sobrecarga de construtores usada neste exemplo não pode indicar ao thread que chama se a propriedade inicial do mutex nomeado foi concedida. Não deve usar este construtor para pedir a propriedade inicial a menos que tenha a certeza de que o thread irá criar o mutex nomeado.

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

Observações

Podem name ser precedidos por Global\ ou Local\ para especificar um namespace. Quando o Global namespace é especificado, o objeto de sincronização pode ser partilhado com quaisquer processos no sistema. Quando o Local namespace é especificado, que é também o padrão quando não há namespace especificado, o objeto de sincronização pode ser partilhado com processos na mesma sessão. No Windows, uma sessão é uma sessão de login, e os serviços normalmente correm numa sessão diferente e não interativa. Em sistemas operativos do tipo Unix, cada shell tem a sua própria sessão. Os objetos de sincronização local da sessão podem ser apropriados para sincronizar entre processos com uma relação pai/filho, onde todos correm na mesma sessão. Para mais informações sobre nomes de objetos de sincronização no Windows, veja Object Names.

Se a name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente é utilizado. Se já existir um objeto de sincronização de outro tipo no namespace, um WaitHandleCannotBeOpenedException lançamento é lançado. Caso contrário, é criado um novo objeto de sincronização.

Se name não null for e initiallyOwned for true, o thread que chamou detém o mutex apenas se o mutex do sistema nomeado foi criado como resultado dessa chamada. Como não existe um mecanismo para determinar se o mutex do sistema nomeado foi criado, é melhor especificar false para initiallyOwned ao chamar esta sobrecarga de construtores. Pode usar o Mutex(Boolean, String, Boolean) construtor se precisar de determinar a propriedade inicial.

Este construtor inicializa um Mutex objeto que representa um sistema mutex nomeado. Podes criar múltiplos Mutex objetos que representam o mesmo sistema com nome, mutex.

Se o mutex nomeado já tiver sido criado com segurança de controlo de acesso e o chamador não tiver MutexRights.FullControl, é lançada uma exceção. Para abrir um mutex nomeado existente apenas com as permissões necessárias para sincronizar atividades de thread, veja o OpenExisting método.

Se especificar null ou uma string vazia para name, é criado um mutex local, como se tivesse chamado o Mutex(Boolean) construtor.

Por serem de todo o sistema, os mutexes nomeados podem ser usados para coordenar o uso de recursos através dos limites dos processos.

Note

Num servidor que executa Terminal Services, um mutex nomeado do sistema pode ter dois níveis de visibilidade. Se o seu nome começar com o prefixo Global\, o mutex é visível em todas as sessões do terminal server. Se o seu nome começar com o prefixo Local\, o mutex é visível apenas na sessão do servidor terminal onde foi criado. Nesse caso, pode existir um mutex separado com o mesmo nome em cada uma das outras sessões do terminal server no servidor. Se não especificar um prefixo ao criar um mutex nomeado, ele assume o prefixo Local\. Dentro de uma sessão de servidor de terminais, dois mutexes cujos nomes diferem apenas pelos seus prefixos são mutexes separados, e ambos são visíveis para todos os processos na sessão do servidor de terminais. Ou seja, os nomes Global\ dos prefixos e Local\ descrevem o âmbito do nome mutex relativamente às sessões do servidor terminal, não relativamente aos processos.

Atenção

Por defeito, um mutex nomeado não está restrito ao utilizador que o criou. Outros utilizadores podem conseguir abrir e usar o mutex, incluindo interferir com ele ao entrar e não sair dele. Em sistemas operativos do tipo Unix, o sistema de ficheiros é usado na implementação de mutexes nomeados, e outros utilizadores podem interferir com mutexes nomeados de formas mais significativas. No Windows, para restringir o acesso a utilizadores específicos, podes usar um constructor overload ou MutexAcl e passar um MutexSecurity ao criar o mutex nomeado. Em sistemas operativos do tipo Unix, atualmente não há forma de restringir o acesso a um mutex nomeado. Evite usar mutexes nomeados sem restrições de acesso em sistemas que possam ter utilizadores não confiáveis a executar código.

A barra inversa (\) é um carácter reservado num nome mutex. Não use uma barra diagonal (\) num nome mutex, exceto conforme especificado na nota sobre o uso de mutexes em sessões de servidor de terminal. Caso contrário, pode ser lançado a DirectoryNotFoundException , mesmo que o nome do mutex represente um ficheiro existente.

Ver também

Aplica-se a

Mutex(String, NamedWaitHandleOptions)

Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com uma string que é o nome do mutex e opções para definir o acesso ao user-scope e session-scope. O fio de chamadas não solicita a posse inicial do 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)

Parâmetros

name
String

O nome, se o objeto de sincronização for partilhado com outros processos; caso contrário, null ou uma cadeia vazia. O nome é sensível a maiúsculas e minúsculas.

options
NamedWaitHandleOptions

As opções de alcance para o sistema nomeado mutex. Por defeito, o acesso é limitado apenas ao utilizador atual e à sessão atual. As opções especificadas podem afetar o espaço de nomes do nome e o acesso ao objeto mutex do sistema subjacente.

Exceções

O mutex nomeado existe e tem segurança de controlo de acesso, mas o utilizador não tem FullControl.

name é inválido. Isto pode dever-se a várias razões, incluindo algumas restrições que podem ser impostas pelo sistema operativo, como um prefixo desconhecido ou caracteres inválidos. Note que o nome e os prefixos comuns "Global\" e "Local\" são sensíveis a maiúsculas minúsculas.

-ou-

Houve outro erro. A HResult propriedade pode fornecer mais informações.

Windows apenas: name especificava um namespace desconhecido. Consulte Nomes dos Objetos para mais informações.

O name é demasiado longo. As restrições de comprimento podem depender do sistema operativo ou da configuração.

Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de outro tipo pode ter o mesmo nome. -ou-

Existe um objeto com o especificado name , mas os especificados options não são compatíveis com as opções do objeto existente.

Observações

Se a name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente é usado. No entanto, se options especificar acesso limitado ao utilizador atual e o objeto de sincronização não for compatível com ele, a WaitHandleCannotBeOpenedException é lançado. Se já existir um objeto de sincronização de um tipo diferente no namespace, um WaitHandleCannotBeOpenedException também é lançado. Caso contrário, é criado um novo objeto de sincronização.

Este construtor inicializa um Mutex objeto que representa um sistema mutex nomeado. Podes criar múltiplos Mutex objetos que representam o mesmo sistema com nome, mutex.

Se o mutex nomeado já tiver sido criado com segurança de controlo de acesso e o chamador não tiver MutexRights.FullControl, é lançada uma exceção. Para abrir um mutex nomeado existente apenas com as permissões necessárias para sincronizar atividades de thread, veja o OpenExisting método.

Se especificar null ou uma string vazia para name, é criado um mutex local, como se tivesse chamado o Mutex(Boolean) construtor.

Por serem de todo o sistema, os mutexes nomeados podem ser usados para coordenar o uso de recursos através dos limites dos processos.

O options parâmetro pode ser fornecido para especificar se o mutex nomeado é acessível apenas ao utilizador atual ou a todos os utilizadores. Também permite especificar se o mutex nomeado é acessível apenas a processos na sessão atual ou a todas as sessões. Para obter mais informações, veja NamedWaitHandleOptions.

A barra inversa (\) é um carácter reservado num nome mutex. Não use uma barra diagonal (\) num nome mutex, exceto conforme especificado na nota sobre o uso de mutexes em sessões de servidor de terminal. Caso contrário, pode ser lançado a DirectoryNotFoundException , mesmo que o nome do mutex represente um ficheiro existente.

Ver também

Aplica-se a

Mutex(Boolean, String, Boolean)

Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se a thread que chama deve ter a propriedade inicial do mutex, uma string que é o nome do mutex e um valor Booleano que, quando o método retorna, indica se a thread que chama recebeu a propriedade inicial do 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)

Parâmetros

initiallyOwned
Boolean

true para dar ao thread que chama a propriedade inicial do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado desta chamada; caso contrário, false.

name
String

O nome, se o objeto de sincronização for partilhado com outros processos; caso contrário, null ou uma cadeia vazia. O nome é sensível a maiúsculas e minúsculas. O carácter de barra inversa (\) é reservado e só pode ser usado para especificar um namespace. Para mais informações sobre namespaces, consulte a secção de observações. Podem existir restrições adicionais quanto ao nome, dependendo do sistema operativo. Por exemplo, em sistemas operativos baseados em Unix, o nome após excluir o espaço de nomes deve ser um nome de ficheiro válido.

createdNew
Boolean

Quando este método retorna, contém um Booleano, ou true seja, se foi criado um mutex local (isto é, se name for null ou uma cadeia vazia) ou se o mutex do sistema nomeado especificado foi criado; false se o mutex do sistema nomeado especificado já existisse. Este parâmetro é passado sem inicializar.

Atributos

Exceções

O mutex nomeado existe e tem segurança de controlo de acesso, mas o utilizador não tem FullControl.

name é inválido. Isto pode dever-se a várias razões, incluindo algumas restrições que podem ser impostas pelo sistema operativo, como um prefixo desconhecido ou caracteres inválidos. Note que o nome e os prefixos comuns "Global\" e "Local\" são sensíveis a maiúsculas minúsculas.

-ou-

Houve outro erro. A HResult propriedade pode fornecer mais informações.

Windows apenas: name especificava um namespace desconhecido. Consulte Nomes dos Objetos para mais informações.

O name é demasiado longo. As restrições de comprimento podem depender do sistema operativo ou da configuração.

Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de outro tipo pode ter o mesmo nome.

.NET Framework apenas: name é mais longo que MAX_PATH (260 caracteres).

Exemplos

O exemplo de código seguinte mostra como um mutex nomeado é usado para sinalizar entre processos ou threads. Executa este programa a partir de duas ou mais janelas de comandos. Cada processo cria um Mutex objeto que representa o mutex nomeado "MyMutex". O mutex nomeado é um objeto do sistema. Neste exemplo, a sua vida útil é limitada pelo tempo de vida dos Mutex objetos que o representam. O mutex nomeado é criado quando o primeiro processo cria o seu objeto local Mutex , e destruído quando todos os Mutex objetos que o representam foram libertados. O mutex nomeado pertence inicialmente ao primeiro processo. O segundo processo e quaisquer processos subsequentes aguardam que processos anteriores libertem o mutex nomeado.

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

Observações

Podem name ser precedidos por Global\ ou Local\ para especificar um namespace. Quando o Global namespace é especificado, o objeto de sincronização pode ser partilhado com quaisquer processos no sistema. Quando o Local namespace é especificado, que é também o padrão quando não há namespace especificado, o objeto de sincronização pode ser partilhado com processos na mesma sessão. No Windows, uma sessão é uma sessão de login, e os serviços normalmente correm numa sessão diferente e não interativa. Em sistemas operativos do tipo Unix, cada shell tem a sua própria sessão. Os objetos de sincronização local da sessão podem ser apropriados para sincronizar entre processos com uma relação pai/filho, onde todos correm na mesma sessão. Para mais informações sobre nomes de objetos de sincronização no Windows, veja Object Names.

Se a name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente é utilizado. Se já existir um objeto de sincronização de outro tipo no namespace, um WaitHandleCannotBeOpenedException lançamento é lançado. Caso contrário, é criado um novo objeto de sincronização.

Se name não null for e initiallyOwned for true, o thread que chama possui o mutex nomeado apenas se createdNew for true após a chamada. Caso contrário, o thread pode solicitar o mutex chamando o WaitOne método.

Este construtor inicializa um Mutex objeto que representa um sistema mutex nomeado. Podes criar múltiplos Mutex objetos que representam o mesmo sistema com nome, mutex.

Se o mutex nomeado já tiver sido criado com segurança de controlo de acesso e o chamador não tiver MutexRights.FullControl direitos, é lançada uma exceção. Para abrir um mutex nomeado existente apenas com as permissões necessárias para sincronizar atividades de thread, veja o OpenExisting método.

Se especificar null ou uma string vazia para name, é criado um mutex local, como se tivesse chamado o Mutex(Boolean) construtor. Neste caso, createdNew é sempre true.

Por serem de todo o sistema, os mutexes nomeados podem ser usados para coordenar o uso de recursos através dos limites dos processos.

Note

Num servidor que executa Terminal Services, um mutex nomeado do sistema pode ter dois níveis de visibilidade. Se o seu nome começar com o prefixo Global\, o mutex é visível em todas as sessões do terminal server. Se o seu nome começar com o prefixo Local\, o mutex é visível apenas na sessão do servidor terminal onde foi criado. Nesse caso, pode existir um mutex separado com o mesmo nome em cada uma das outras sessões do terminal server no servidor. Se não especificar um prefixo ao criar um mutex nomeado, ele assume o prefixo Local\. Dentro de uma sessão de servidor de terminais, dois mutexes cujos nomes diferem apenas pelos seus prefixos são mutexes separados, e ambos são visíveis para todos os processos na sessão do servidor de terminais. Ou seja, os nomes Global\ dos prefixos e Local\ descrevem o âmbito do nome mutex relativamente às sessões do servidor terminal, não relativamente aos processos.

Atenção

Por defeito, um mutex nomeado não está restrito ao utilizador que o criou. Outros utilizadores podem conseguir abrir e usar o mutex, incluindo interferir com ele ao entrar e não sair dele. Em sistemas operativos do tipo Unix, o sistema de ficheiros é usado na implementação de mutexes nomeados, e outros utilizadores podem interferir com mutexes nomeados de formas mais significativas. No Windows, para restringir o acesso a utilizadores específicos, podes usar um constructor overload ou MutexAcl e passar um MutexSecurity ao criar o mutex nomeado. Em sistemas operativos do tipo Unix, atualmente não há forma de restringir o acesso a um mutex nomeado. Evite usar mutexes nomeados sem restrições de acesso em sistemas que possam ter utilizadores não confiáveis a executar código.

A barra inversa (\) é um carácter reservado num nome mutex. Não use uma barra diagonal (\) num nome mutex, exceto conforme especificado na nota sobre o uso de mutexes em sessões de servidor de terminal. Caso contrário, pode ser lançado a DirectoryNotFoundException , mesmo que o nome do mutex represente um ficheiro existente.

Ver também

Aplica-se a

Mutex(Boolean, String, NamedWaitHandleOptions)

Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread que chama deve ter propriedade inicial do mutex, uma string que é o nome do mutex e opções para definir o acesso ao âmbito do utilizador e ao âmbito da sessão.

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)

Parâmetros

initiallyOwned
Boolean

true para dar ao thread que chama a propriedade inicial do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado desta chamada; caso contrário, false.

name
String

O nome, se o objeto de sincronização for partilhado com outros processos; caso contrário, null ou uma cadeia vazia. O nome é sensível a maiúsculas e minúsculas.

options
NamedWaitHandleOptions

As opções de alcance para o sistema nomeado mutex. Por defeito, o acesso é limitado apenas ao utilizador atual e à sessão atual. As opções especificadas podem afetar o espaço de nomes do nome e o acesso ao objeto mutex do sistema subjacente.

Exceções

O mutex nomeado existe e tem segurança de controlo de acesso, mas o utilizador não tem FullControl.

name é inválido. Isto pode dever-se a várias razões, incluindo algumas restrições que podem ser impostas pelo sistema operativo, como um prefixo desconhecido ou caracteres inválidos. Note que o nome e os prefixos comuns "Global\" e "Local\" são sensíveis a maiúsculas minúsculas.

-ou-

Houve outro erro. A HResult propriedade pode fornecer mais informações.

Windows apenas: name especificava um namespace desconhecido. Consulte Nomes dos Objetos para mais informações.

O name é demasiado longo. As restrições de comprimento podem depender do sistema operativo ou da configuração.

Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de outro tipo pode ter o mesmo nome. -ou-

Existe um objeto com o especificado name , mas os especificados options não são compatíveis com as opções do objeto existente.

Observações

Se a name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente é usado. No entanto, se options especificar acesso limitado ao utilizador atual e o objeto de sincronização não for compatível com ele, a WaitHandleCannotBeOpenedException é lançado. Se já existir um objeto de sincronização de um tipo diferente no namespace, um WaitHandleCannotBeOpenedException também é lançado. Caso contrário, é criado um novo objeto de sincronização.

Se name não null for e initiallyOwned for true, o thread que chamou detém o mutex apenas se o mutex do sistema nomeado foi criado como resultado dessa chamada. Como não existe um mecanismo para determinar se o mutex do sistema nomeado foi criado, é melhor especificar false para initiallyOwned ao chamar esta sobrecarga de construtores. Pode usar o Mutex(Boolean, String, Boolean) construtor se precisar de determinar a propriedade inicial.

Este construtor inicializa um Mutex objeto que representa um sistema mutex nomeado. Podes criar múltiplos Mutex objetos que representam o mesmo sistema com nome, mutex.

Se o mutex nomeado já tiver sido criado com segurança de controlo de acesso e o chamador não tiver MutexRights.FullControl, é lançada uma exceção. Para abrir um mutex nomeado existente apenas com as permissões necessárias para sincronizar atividades de thread, veja o OpenExisting método.

Se especificar null ou uma string vazia para name, é criado um mutex local, como se tivesse chamado o Mutex(Boolean) construtor.

Por serem de todo o sistema, os mutexes nomeados podem ser usados para coordenar o uso de recursos através dos limites dos processos.

O options parâmetro pode ser fornecido para especificar se o mutex nomeado é acessível apenas ao utilizador atual ou a todos os utilizadores. Também permite especificar se o mutex nomeado é acessível apenas a processos na sessão atual ou a todas as sessões. Para obter mais informações, veja NamedWaitHandleOptions.

Ver também

Aplica-se a

Mutex(Boolean, String, Boolean, MutexSecurity)

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se a thread chamadora deve ter propriedade inicial do mutex, uma string que é o nome do mutex, uma variável Booleana que, quando o método retorna, indica se a thread chamadora recebeu a propriedade inicial do mutex e a segurança de controlo de acesso a ser aplicada ao mutex nomeado.

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)

Parâmetros

initiallyOwned
Boolean

true para dar ao thread que chama a propriedade inicial do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado desta chamada; caso contrário, false.

name
String

O nome, se o objeto de sincronização for partilhado com outros processos; caso contrário, null ou uma cadeia vazia. O nome é sensível a maiúsculas e minúsculas. O carácter de barra inversa (\) é reservado e só pode ser usado para especificar um namespace. Para mais informações sobre namespaces, consulte a secção de observações. Podem existir restrições adicionais quanto ao nome, dependendo do sistema operativo. Por exemplo, em sistemas operativos baseados em Unix, o nome após excluir o espaço de nomes deve ser um nome de ficheiro válido.

createdNew
Boolean

Quando este método retorna, contém um Booleano, ou true seja, se foi criado um mutex local (isto é, se name for null ou uma cadeia vazia) ou se o mutex do sistema nomeado especificado foi criado; false se o mutex do sistema nomeado especificado já existisse. Este parâmetro é passado sem inicializar.

mutexSecurity
MutexSecurity

Um MutexSecurity objeto que representa a segurança de controlo de acesso a ser aplicada ao mutex do sistema nomeado.

Atributos

Exceções

name é inválido. Isto pode dever-se a várias razões, incluindo algumas restrições que podem ser impostas pelo sistema operativo, como um prefixo desconhecido ou caracteres inválidos. Note que o nome e os prefixos comuns "Global\" e "Local\" são sensíveis a maiúsculas minúsculas.

-ou-

Houve outro erro. A HResult propriedade pode fornecer mais informações.

Windows apenas: name especificava um namespace desconhecido. Consulte Nomes dos Objetos para mais informações.

O name é demasiado longo. As restrições de comprimento podem depender do sistema operativo ou da configuração.

O mutex nomeado existe e tem segurança de controlo de acesso, mas o utilizador não tem FullControl.

Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de outro tipo pode ter o mesmo nome.

.NET Framework apenas: name é mais longo que MAX_PATH (260 caracteres).

Exemplos

O exemplo de código seguinte demonstra o comportamento cruzado de processos de um mutex nomeado com segurança de controlo de acesso. O exemplo utiliza a OpenExisting(String) sobrecarga de métodos para testar a existência de um mutex nomeado.

Se o mutex não existir, é criado com propriedade inicial e segurança de controlo de acessos que nega ao utilizador atual o direito de usar o mutex, mas concede o direito de ler e alterar permissões no mutex.

Se executares o exemplo compilado a partir de duas janelas de comandos, a segunda cópia irá lançar uma exceção de violação de acesso na chamada para OpenExisting(String). A exceção é apanhada, e o exemplo usa a OpenExisting(String, MutexRights) sobrecarga de métodos para abrir o mutex com os direitos necessários para ler e alterar as permissões.

Depois de as permissões serem alteradas, o mutex é aberto com os direitos necessários para entrar e libertá-lo. Se executares o exemplo compilado a partir de uma terceira janela de comandos, ele é executado usando as novas permissões.

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

Observações

Podem name ser precedidos por Global\ ou Local\ para especificar um namespace. Quando o Global namespace é especificado, o objeto de sincronização pode ser partilhado com quaisquer processos no sistema. Quando o Local namespace é especificado, que é também o padrão quando não há namespace especificado, o objeto de sincronização pode ser partilhado com processos na mesma sessão. No Windows, uma sessão é uma sessão de login, e os serviços normalmente correm numa sessão diferente e não interativa. Em sistemas operativos do tipo Unix, cada shell tem a sua própria sessão. Os objetos de sincronização local da sessão podem ser apropriados para sincronizar entre processos com uma relação pai/filho, onde todos correm na mesma sessão. Para mais informações sobre nomes de objetos de sincronização no Windows, veja Object Names.

Se a name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente é utilizado. Se já existir um objeto de sincronização de outro tipo no namespace, um WaitHandleCannotBeOpenedException lançamento é lançado. Caso contrário, é criado um novo objeto de sincronização.

Se name não null for e initiallyOwned for true, o thread que chama possui o mutex nomeado apenas se createdNew for true após a chamada. Caso contrário, o thread pode solicitar o mutex chamando o WaitOne método.

Use este construtor para aplicar segurança de controlo de acesso a um mutex nomeado do sistema quando este é criado, impedindo que outro código tome controlo do mutex.

Este construtor inicializa um Mutex objeto que representa um sistema mutex nomeado. Podes criar múltiplos Mutex objetos que representam o mesmo sistema com nome, mutex.

Se o mutex do sistema nomeado não existir, é criado com a segurança de controlo de acesso especificada. Se o mutex nomeado existir, a segurança de controlo de acesso especificada é ignorada.

Note

O chamador tem controlo total sobre o objeto recém-criado Mutex , mesmo que mutexSecurity negue ou não conceda alguns direitos de acesso ao utilizador atual. No entanto, se o utilizador atual tentar fazer com que outro objeto Mutex represente o mesmo mutex nomeado, usando um construtor ou o método OpenExisting, é aplicada Windows segurança de controlo de acesso.

Se o mutex nomeado já tiver sido criado com segurança de controlo de acesso e o chamador não tiver MutexRights.FullControl, é lançada uma exceção. Para abrir um mutex nomeado existente apenas com as permissões necessárias para sincronizar atividades de thread, veja o OpenExisting método.

Se especificar null ou uma string vazia para name, é criado um mutex local, como se tivesse chamado o Mutex(Boolean) construtor. Neste caso, createdNew é sempre true.

Por serem de todo o sistema, os mutexes nomeados podem ser usados para coordenar o uso de recursos através dos limites dos processos.

Note

Num servidor que executa Terminal Services, um mutex nomeado do sistema pode ter dois níveis de visibilidade. Se o seu nome começar com o prefixo Global\, o mutex é visível em todas as sessões do terminal server. Se o seu nome começar com o prefixo Local\, o mutex é visível apenas na sessão do servidor terminal onde foi criado. Nesse caso, pode existir um mutex separado com o mesmo nome em cada uma das outras sessões do terminal server no servidor. Se não especificar um prefixo ao criar um mutex nomeado, ele assume o prefixo Local\. Dentro de uma sessão de servidor de terminais, dois mutexes cujos nomes diferem apenas pelos seus prefixos são mutexes separados, e ambos são visíveis para todos os processos na sessão do servidor de terminais. Ou seja, os nomes Global\ dos prefixos e Local\ descrevem o âmbito do nome mutex relativamente às sessões do servidor terminal, não relativamente aos processos.

Atenção

Por defeito, um mutex nomeado não está restrito ao utilizador que o criou. Outros utilizadores podem conseguir abrir e usar o mutex, incluindo interferir com ele ao entrar e não sair dele. Para restringir o acesso a utilizadores específicos, podes passar um MutexSecurity a ao criar o mutex nomeado. Evite usar mutexes nomeados sem restrições de acesso em sistemas que possam ter utilizadores não confiáveis a executar código.

A barra inversa (\) é um carácter reservado num nome mutex. Não use uma barra diagonal (\) num nome mutex, exceto conforme especificado na nota sobre o uso de mutexes em sessões de servidor de terminal. Caso contrário, pode ser lançado a DirectoryNotFoundException , mesmo que o nome do mutex represente um ficheiro existente.

Aplica-se a

Mutex(Boolean, String, NamedWaitHandleOptions, Boolean)

Origem:
Mutex.cs
Origem:
Mutex.cs

Inicializa uma nova instância da Mutex classe com um valor Booleano que indica se o thread que chama deve ter propriedade inicial do mutex, uma string que é o nome do mutex, opções para definir o acesso ao user-scope e session-scope, e um valor Booleano que, quando o método retorna, indica se o thread chamador recebeu a propriedade inicial do 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)

Parâmetros

initiallyOwned
Boolean

true para dar ao thread que chama a propriedade inicial do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado desta chamada; caso contrário, false.

name
String

O nome, se o objeto de sincronização for partilhado com outros processos; caso contrário, null ou uma cadeia vazia. O nome é sensível a maiúsculas e minúsculas.

options
NamedWaitHandleOptions

As opções de alcance para o sistema nomeado mutex. Por defeito, o acesso é limitado apenas ao utilizador atual e à sessão atual. As opções especificadas podem afetar o espaço de nomes do nome e o acesso ao objeto mutex do sistema subjacente.

createdNew
Boolean

Quando este método retorna, contém um Booleano, ou seja true , se foi criado um mutex local (isto é, se name for null ou uma cadeia vazia) ou se o mutex do sistema nomeado especificado foi criado; contém false se o mutex do sistema nomeado especificado já existisse. Este parâmetro é passado sem inicializar.

Exceções

O mutex nomeado existe e tem segurança de controlo de acesso, mas o utilizador não tem FullControl.

name é inválido. Isto pode dever-se a várias razões, incluindo algumas restrições que podem ser impostas pelo sistema operativo, como um prefixo desconhecido ou caracteres inválidos. Note que o nome e os prefixos comuns "Global\" e "Local\" são sensíveis a maiúsculas minúsculas.

-ou-

Houve outro erro. A HResult propriedade pode fornecer mais informações.

Windows apenas: name especificava um namespace desconhecido. Consulte Nomes dos Objetos para mais informações.

O name é demasiado longo. As restrições de comprimento podem depender do sistema operativo ou da configuração.

Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de outro tipo pode ter o mesmo nome. -ou-

Existe um objeto com o especificado name , mas os especificados options não são compatíveis com as opções do objeto existente.

Observações

Se a name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente é usado. No entanto, se options especificar acesso limitado ao utilizador atual e o objeto de sincronização não for compatível com ele, a WaitHandleCannotBeOpenedException é lançado. Se já existir um objeto de sincronização de um tipo diferente no namespace, um WaitHandleCannotBeOpenedException também é lançado. Caso contrário, é criado um novo objeto de sincronização.

Se name não null for e initiallyOwned for true, o thread que chama possui o mutex nomeado apenas se createdNew for true após a chamada. Caso contrário, o thread pode solicitar o mutex chamando o WaitOne método.

Este construtor inicializa um Mutex objeto que representa um sistema mutex nomeado. Podes criar múltiplos Mutex objetos que representam o mesmo sistema com nome, mutex.

Se o mutex nomeado já tiver sido criado com segurança de controlo de acesso e o chamador não tiver MutexRights.FullControl direitos, é lançada uma exceção. Para abrir um mutex nomeado existente apenas com as permissões necessárias para sincronizar atividades de thread, veja o OpenExisting método.

Se especificar null ou uma string vazia para name, é criado um mutex local, como se tivesse chamado o Mutex(Boolean) construtor. Neste caso, createdNew é sempre true.

Por serem de todo o sistema, os mutexes nomeados podem ser usados para coordenar o uso de recursos através dos limites dos processos.

O options parâmetro pode ser fornecido para especificar se o mutex nomeado é acessível apenas ao utilizador atual ou a todos os utilizadores. Também permite especificar se o mutex nomeado é acessível apenas a processos na sessão atual ou a todas as sessões. Para obter mais informações, veja NamedWaitHandleOptions.

Ver também

Aplica-se a