Mutex Construtores
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Inicializa uma nova instância da classe Mutex.
Sobrecargas
| Nome | Description |
|---|---|
| Mutex() |
Inicializa uma nova instância da Mutex classe com propriedades padrão. |
| Mutex(Boolean) |
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex. |
| Mutex(Boolean, String) |
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex e uma cadeia de caracteres que é o nome do mutex. |
| Mutex(String, NamedWaitHandleOptions) |
Inicializa uma nova instância da Mutex classe com uma cadeia de caracteres que é o nome do mutex e opções para definir o escopo do usuário e o acesso ao escopo da sessão. O thread de chamada não solicita ter a propriedade inicial do mutex. |
| Mutex(Boolean, String, Boolean) |
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex e um valor booliano que, quando o método retorna, indica se o thread de chamada recebeu a propriedade inicial do mutex. |
| Mutex(Boolean, String, NamedWaitHandleOptions) |
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex e opções para definir o escopo do usuário e o acesso ao escopo da sessão. |
| Mutex(Boolean, String, Boolean, MutexSecurity) |
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex, uma variável booliana que, quando o método retorna, indica se o thread de chamada recebeu a propriedade inicial do mutex e a segurança de controle de acesso a ser aplicada ao mutex nomeado. |
| Mutex(Boolean, String, NamedWaitHandleOptions, Boolean) |
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex, opções para definir o escopo do usuário e o acesso ao escopo da sessão e um valor booliano que, quando o método retorna, indica se o thread de chamada 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 padrão.
public:
Mutex();
public Mutex();
Public Sub New ()
Exemplos
O exemplo de código a seguir 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
Comentários
Chamar essa sobrecarga de construtor é o mesmo que chamar a sobrecarga do Mutex(Boolean) construtor e especificar false a propriedade inicial do mutex. Ou seja, o thread de chamada não é proprietário do mutex.
Confira 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 booliano que indica se o thread de chamada 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 fornecer a propriedade inicial do thread de chamada do mutex; caso contrário, false.
Exemplos
O exemplo de código a seguir mostra como um objeto local Mutex é usado para sincronizar o acesso a um recurso protegido. O thread que cria o Mutex próprio 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
Confira 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 booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex e uma cadeia de caracteres 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 fornecer a propriedade inicial do thread de chamada do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado dessa chamada; caso contrário, false.
- name
- String
O nome, se o objeto de sincronização deve ser compartilhado com outros processos; caso contrário, null ou uma cadeia de caracteres vazia. O nome diferencia maiúsculas de minúsculas. O caractere de barra invertida (\) é reservado e só pode ser usado para especificar um namespace. Para obter mais informações sobre namespaces, consulte a seção comentários. Pode haver mais restrições ao nome dependendo do sistema operacional. Por exemplo, em sistemas operacionais baseados em Unix, o nome após a exclusão do namespace deve ser um nome de arquivo válido.
- Atributos
Exceções
O mutex nomeado existe e tem segurança de controle de acesso, mas o usuário não tem FullControl.
name é inválido. Isso pode ser por vários motivos, incluindo algumas restrições que podem ser colocadas pelo sistema operacional, como um prefixo desconhecido ou caracteres inválidos. Observe que o nome e os prefixos comuns "Global\" e "Local\" diferenciam maiúsculas de minúsculas.
- ou -
Houve outro erro. A HResult propriedade pode fornecer mais informações.
Windows somente: name especificado um namespace desconhecido. Consulte Nomes de Objetos para obter mais informações.
O name é muito longo. As restrições de comprimento podem depender do sistema operacional ou da configuração.
Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de um tipo diferente pode ter o mesmo nome.
.NET Framework somente: name é maior que MAX_PATH (260 caracteres).
Exemplos
O exemplo a seguir mostra como um mutex nomeado é usado para sinalizar entre threads em execução em dois processos separados.
Execute este programa em duas ou mais janelas de comando. 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 objetos que o Mutex representam. O mutex nomeado é criado quando o primeiro processo cria seu Mutex objeto; neste exemplo, o mutex nomeado pertence ao primeiro processo que executa o programa. O mutex nomeado é destruído quando todos os objetos que o Mutex representam foram liberados.
A sobrecarga do construtor usada neste exemplo não pode informar ao thread de chamada se a propriedade inicial do mutex nomeado foi concedida. Você não deve usar esse construtor para solicitar a propriedade inicial, a menos que possa ter certeza de que o thread 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
Comentários
Pode name ser prefixado com Global\ ou Local\ para especificar um namespace. Quando o Global namespace é especificado, o objeto de sincronização pode ser compartilhado com todos os processos no sistema. Quando o Local namespace é especificado, que também é o padrão quando nenhum namespace é especificado, o objeto de sincronização pode ser compartilhado com processos na mesma sessão. No Windows, uma sessão é uma sessão de logon e os serviços normalmente são executados em uma sessão não interativa diferente. Em sistemas operacionais semelhantes ao Unix, cada shell tem sua própria sessão. Os objetos de sincronização local de sessão podem ser apropriados para sincronizar entre processos com uma relação pai/filho em que todos eles são executados na mesma sessão. Para obter mais informações sobre nomes de objetos de sincronização no Windows, consulte Object Names.
Se um name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente será usado. Se um objeto de sincronização de um tipo diferente já existir no namespace, um WaitHandleCannotBeOpenedException será gerado. Caso contrário, um novo objeto de sincronização será criado.
Se name não null for e initiallyOwned for true, o thread de chamada será proprietário do mutex somente se o mutex do sistema nomeado tiver sido criado como resultado dessa chamada. Como não há mecanismo para determinar se o mutex do sistema nomeado foi criado, é melhor especificar false ao initiallyOwned chamar essa sobrecarga de construtor. Você pode usar o Mutex(Boolean, String, Boolean) construtor se precisar determinar a propriedade inicial.
Esse construtor inicializa um Mutex objeto que representa um mutex de sistema nomeado. Você pode criar vários Mutex objetos que representam o mesmo mutex do sistema nomeado.
Se o mutex nomeado já tiver sido criado com segurança de controle de acesso e o chamador não tiver MutexRights.FullControl, uma exceção será gerada. Para abrir um mutex nomeado existente com apenas as permissões necessárias para sincronizar atividades de thread, consulte o OpenExisting método.
Se você especificar null ou uma cadeia de caracteres vazia para name, um mutex local será criado, como se você tivesse chamado o Mutex(Boolean) construtor.
Como eles são de todo o sistema, mutexes nomeados podem ser usados para coordenar o uso de recursos entre os limites do processo.
Note
Em um servidor que está executando os Serviços de Terminal, um mutex de sistema nomeado pode ter dois níveis de visibilidade. Se seu nome começar com o prefixo Global\, o mutex ficará visível em todas as sessões do servidor de terminal. Se seu nome começar com o prefixo Local\, o mutex ficará visível apenas na sessão do servidor terminal em que foi criado. Nesse caso, um mutex separado com o mesmo nome pode existir em cada uma das outras sessões de servidor de terminal no servidor. Se você não especificar um prefixo ao criar um mutex nomeado, ele usará o prefixo Local\. Em uma sessão de servidor terminal, dois mutexes cujos nomes diferem apenas por seus prefixos são mutexes separados e ambos são visíveis para todos os processos na sessão do servidor terminal. Ou seja, os nomes Global\ de prefixo e Local\ descrevem o escopo do nome mutex em relação às sessões do servidor terminal, não em relação aos processos.
Caution
Por padrão, um mutex nomeado não é restrito ao usuário que o criou. Outros usuários podem ser capazes de abrir e usar o mutex, incluindo interferir com o mutex inserindo o mutex e não saindo dele. Em sistemas operacionais semelhantes ao Unix, o sistema de arquivos é usado na implementação de mutexes nomeados e outros usuários podem interferir em mutexes nomeados de maneiras mais significativas. Em Windows, para restringir o acesso a usuários específicos, você pode usar uma sobrecarga de construtor ou MutexAcl e passar um MutexSecurity ao criar o mutex nomeado. Em sistemas operacionais semelhantes ao Unix, atualmente não há como restringir o acesso a um mutex nomeado. Evite usar mutexes nomeados sem restrições de acesso em sistemas que podem ter usuários não confiáveis executando código.
A barra invertida (\) é um caractere reservado em um nome mutex. Não use uma barra invertida (\) em um nome mutex, exceto conforme especificado na observação sobre como usar mutexes em sessões de servidor de terminal. Caso contrário, um DirectoryNotFoundException pode ser gerado, mesmo que o nome do mutex represente um arquivo existente.
Confira também
Aplica-se a
Mutex(String, NamedWaitHandleOptions)
- Origem:
- Mutex.cs
- Origem:
- Mutex.cs
Inicializa uma nova instância da Mutex classe com uma cadeia de caracteres que é o nome do mutex e opções para definir o escopo do usuário e o acesso ao escopo da sessão. O thread de chamada não solicita ter a propriedade 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 deve ser compartilhado com outros processos; caso contrário, null ou uma cadeia de caracteres vazia. O nome diferencia maiúsculas de minúsculas.
- options
- NamedWaitHandleOptions
As opções de escopo para o mutex do sistema nomeado. O padrão é acessar apenas o usuário atual e a sessão atual. As opções especificadas podem afetar o namespace para o nome e o acesso ao objeto mutex do sistema subjacente.
Exceções
O mutex nomeado existe e tem segurança de controle de acesso, mas o usuário não tem FullControl.
name é inválido. Isso pode ser por vários motivos, incluindo algumas restrições que podem ser colocadas pelo sistema operacional, como um prefixo desconhecido ou caracteres inválidos. Observe que o nome e os prefixos comuns "Global\" e "Local\" diferenciam maiúsculas de minúsculas.
- ou -
Houve outro erro. A HResult propriedade pode fornecer mais informações.
Windows somente: name especificado um namespace desconhecido. Consulte Nomes de Objetos para obter mais informações.
O name é muito longo. As restrições de comprimento podem depender do sistema operacional ou da configuração.
Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de um tipo diferente pode ter o mesmo nome.
- ou -
Um objeto com o especificado name existe, mas os especificados options não são compatíveis com as opções do objeto existente.
Comentários
Se um name objeto de sincronização for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente será usado, no entanto, se options especificar o acesso limitado ao usuário atual e o objeto de sincronização não for compatível com ele, um WaitHandleCannotBeOpenedException será gerado. Se um objeto de sincronização de um tipo diferente já existir no namespace, um WaitHandleCannotBeOpenedException também será gerado. Caso contrário, um novo objeto de sincronização será criado.
Esse construtor inicializa um Mutex objeto que representa um mutex de sistema nomeado. Você pode criar vários Mutex objetos que representam o mesmo mutex do sistema nomeado.
Se o mutex nomeado já tiver sido criado com segurança de controle de acesso e o chamador não tiver MutexRights.FullControl, uma exceção será gerada. Para abrir um mutex nomeado existente com apenas as permissões necessárias para sincronizar atividades de thread, consulte o OpenExisting método.
Se você especificar null ou uma cadeia de caracteres vazia para name, um mutex local será criado, como se você tivesse chamado o Mutex(Boolean) construtor.
Como eles são de todo o sistema, mutexes nomeados podem ser usados para coordenar o uso de recursos entre os limites do processo.
O options parâmetro pode ser fornecido para especificar se o mutex nomeado está acessível somente ao usuário atual ou a todos os usuários. Ele também permite que você especifique se o mutex nomeado está acessível apenas para processos na sessão atual ou para todas as sessões. Para obter mais informações, consulte NamedWaitHandleOptions.
A barra invertida (\) é um caractere reservado em um nome mutex. Não use uma barra invertida (\) em um nome mutex, exceto conforme especificado na observação sobre como usar mutexes em sessões de servidor de terminal. Caso contrário, um DirectoryNotFoundException pode ser gerado, mesmo que o nome do mutex represente um arquivo existente.
Confira 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 booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex e um valor booliano que, quando o método retorna, indica se o thread de chamada 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 fornecer a propriedade inicial do thread de chamada do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado dessa chamada; caso contrário, false.
- name
- String
O nome, se o objeto de sincronização deve ser compartilhado com outros processos; caso contrário, null ou uma cadeia de caracteres vazia. O nome diferencia maiúsculas de minúsculas. O caractere de barra invertida (\) é reservado e só pode ser usado para especificar um namespace. Para obter mais informações sobre namespaces, consulte a seção comentários. Pode haver mais restrições ao nome dependendo do sistema operacional. Por exemplo, em sistemas operacionais baseados em Unix, o nome após a exclusão do namespace deve ser um nome de arquivo válido.
- createdNew
- Boolean
Quando esse método é retornado, contém um booliano que é true se um mutex local foi criado (ou seja, se name é null ou uma cadeia de caracteres vazia) ou se o mutex do sistema nomeado especificado foi criado; false se o mutex do sistema nomeado especificado já existia. Esse parâmetro é passado sem inicialização.
- Atributos
Exceções
O mutex nomeado existe e tem segurança de controle de acesso, mas o usuário não tem FullControl.
name é inválido. Isso pode ser por vários motivos, incluindo algumas restrições que podem ser colocadas pelo sistema operacional, como um prefixo desconhecido ou caracteres inválidos. Observe que o nome e os prefixos comuns "Global\" e "Local\" diferenciam maiúsculas de minúsculas.
- ou -
Houve outro erro. A HResult propriedade pode fornecer mais informações.
Windows somente: name especificado um namespace desconhecido. Consulte Nomes de Objetos para obter mais informações.
O name é muito longo. As restrições de comprimento podem depender do sistema operacional ou da configuração.
Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de um tipo diferente pode ter o mesmo nome.
.NET Framework somente: name é maior que MAX_PATH (260 caracteres).
Exemplos
O exemplo de código a seguir mostra como um mutex nomeado é usado para sinalizar entre processos ou threads. Execute este programa em duas ou mais janelas de comando. Cada processo cria um Mutex objeto que representa o nome mutex "MyMutex". O mutex nomeado é um objeto do sistema. Neste exemplo, seu tempo de vida é limitado pelos tempos de vida dos objetos que o Mutex representam. O mutex nomeado é criado quando o primeiro processo cria seu objeto local Mutex e destruído quando todos os objetos que o Mutex representam são liberados. O mutex nomeado pertence inicialmente ao primeiro processo. O segundo processo e os processos subsequentes aguardam que processos anteriores liberem 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
Comentários
Pode name ser prefixado com Global\ ou Local\ para especificar um namespace. Quando o Global namespace é especificado, o objeto de sincronização pode ser compartilhado com todos os processos no sistema. Quando o Local namespace é especificado, que também é o padrão quando nenhum namespace é especificado, o objeto de sincronização pode ser compartilhado com processos na mesma sessão. No Windows, uma sessão é uma sessão de logon e os serviços normalmente são executados em uma sessão não interativa diferente. Em sistemas operacionais semelhantes ao Unix, cada shell tem sua própria sessão. Os objetos de sincronização local de sessão podem ser apropriados para sincronizar entre processos com uma relação pai/filho em que todos eles são executados na mesma sessão. Para obter mais informações sobre nomes de objetos de sincronização no Windows, consulte Object Names.
Se um name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente será usado. Se um objeto de sincronização de um tipo diferente já existir no namespace, um WaitHandleCannotBeOpenedException será gerado. Caso contrário, um novo objeto de sincronização será criado.
Se name não null for e initiallyOwned for true, o thread de chamada será proprietário do mutex nomeado somente se createdNew estiver true após a chamada. Caso contrário, o thread poderá solicitar o mutex chamando o WaitOne método.
Esse construtor inicializa um Mutex objeto que representa um mutex de sistema nomeado. Você pode criar vários Mutex objetos que representam o mesmo mutex do sistema nomeado.
Se o mutex nomeado já tiver sido criado com segurança de controle de acesso e o chamador não tiver MutexRights.FullControl direitos, uma exceção será gerada. Para abrir um mutex nomeado existente com apenas as permissões necessárias para sincronizar atividades de thread, consulte o OpenExisting método.
Se você especificar null ou uma cadeia de caracteres vazia para name, um mutex local será criado, como se você tivesse chamado o Mutex(Boolean) construtor. Nesse caso, createdNew é sempre true.
Como eles são de todo o sistema, mutexes nomeados podem ser usados para coordenar o uso de recursos entre os limites do processo.
Note
Em um servidor que está executando os Serviços de Terminal, um mutex de sistema nomeado pode ter dois níveis de visibilidade. Se seu nome começar com o prefixo Global\, o mutex ficará visível em todas as sessões do servidor de terminal. Se seu nome começar com o prefixo Local\, o mutex ficará visível apenas na sessão do servidor terminal em que foi criado. Nesse caso, um mutex separado com o mesmo nome pode existir em cada uma das outras sessões de servidor de terminal no servidor. Se você não especificar um prefixo ao criar um mutex nomeado, ele usará o prefixo Local\. Em uma sessão de servidor terminal, dois mutexes cujos nomes diferem apenas por seus prefixos são mutexes separados e ambos são visíveis para todos os processos na sessão do servidor terminal. Ou seja, os nomes Global\ de prefixo e Local\ descrevem o escopo do nome mutex em relação às sessões do servidor terminal, não em relação aos processos.
Caution
Por padrão, um mutex nomeado não é restrito ao usuário que o criou. Outros usuários podem ser capazes de abrir e usar o mutex, incluindo interferir com o mutex inserindo o mutex e não saindo dele. Em sistemas operacionais semelhantes ao Unix, o sistema de arquivos é usado na implementação de mutexes nomeados e outros usuários podem interferir em mutexes nomeados de maneiras mais significativas. Em Windows, para restringir o acesso a usuários específicos, você pode usar uma sobrecarga de construtor ou MutexAcl e passar um MutexSecurity ao criar o mutex nomeado. Em sistemas operacionais semelhantes ao Unix, atualmente não há como restringir o acesso a um mutex nomeado. Evite usar mutexes nomeados sem restrições de acesso em sistemas que podem ter usuários não confiáveis executando código.
A barra invertida (\) é um caractere reservado em um nome mutex. Não use uma barra invertida (\) em um nome mutex, exceto conforme especificado na observação sobre como usar mutexes em sessões de servidor de terminal. Caso contrário, um DirectoryNotFoundException pode ser gerado, mesmo que o nome do mutex represente um arquivo existente.
Confira 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 booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex e opções para definir o escopo do usuário e o acesso ao escopo 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 fornecer a propriedade inicial do thread de chamada do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado dessa chamada; caso contrário, false.
- name
- String
O nome, se o objeto de sincronização deve ser compartilhado com outros processos; caso contrário, null ou uma cadeia de caracteres vazia. O nome diferencia maiúsculas de minúsculas.
- options
- NamedWaitHandleOptions
As opções de escopo para o mutex do sistema nomeado. O padrão é acessar apenas o usuário atual e a sessão atual. As opções especificadas podem afetar o namespace para o nome e o acesso ao objeto mutex do sistema subjacente.
Exceções
O mutex nomeado existe e tem segurança de controle de acesso, mas o usuário não tem FullControl.
name é inválido. Isso pode ser por vários motivos, incluindo algumas restrições que podem ser colocadas pelo sistema operacional, como um prefixo desconhecido ou caracteres inválidos. Observe que o nome e os prefixos comuns "Global\" e "Local\" diferenciam maiúsculas de minúsculas.
- ou -
Houve outro erro. A HResult propriedade pode fornecer mais informações.
Windows somente: name especificado um namespace desconhecido. Consulte Nomes de Objetos para obter mais informações.
O name é muito longo. As restrições de comprimento podem depender do sistema operacional ou da configuração.
Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de um tipo diferente pode ter o mesmo nome.
- ou -
Um objeto com o especificado name existe, mas os especificados options não são compatíveis com as opções do objeto existente.
Comentários
Se um name objeto de sincronização for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente será usado, no entanto, se options especificar o acesso limitado ao usuário atual e o objeto de sincronização não for compatível com ele, um WaitHandleCannotBeOpenedException será gerado. Se um objeto de sincronização de um tipo diferente já existir no namespace, um WaitHandleCannotBeOpenedException também será gerado. Caso contrário, um novo objeto de sincronização será criado.
Se name não null for e initiallyOwned for true, o thread de chamada será proprietário do mutex somente se o mutex do sistema nomeado tiver sido criado como resultado dessa chamada. Como não há mecanismo para determinar se o mutex do sistema nomeado foi criado, é melhor especificar false ao initiallyOwned chamar essa sobrecarga de construtor. Você pode usar o Mutex(Boolean, String, Boolean) construtor se precisar determinar a propriedade inicial.
Esse construtor inicializa um Mutex objeto que representa um mutex de sistema nomeado. Você pode criar vários Mutex objetos que representam o mesmo mutex do sistema nomeado.
Se o mutex nomeado já tiver sido criado com segurança de controle de acesso e o chamador não tiver MutexRights.FullControl, uma exceção será gerada. Para abrir um mutex nomeado existente com apenas as permissões necessárias para sincronizar atividades de thread, consulte o OpenExisting método.
Se você especificar null ou uma cadeia de caracteres vazia para name, um mutex local será criado, como se você tivesse chamado o Mutex(Boolean) construtor.
Como eles são de todo o sistema, mutexes nomeados podem ser usados para coordenar o uso de recursos entre os limites do processo.
O options parâmetro pode ser fornecido para especificar se o mutex nomeado está acessível somente ao usuário atual ou a todos os usuários. Ele também permite que você especifique se o mutex nomeado está acessível apenas para processos na sessão atual ou para todas as sessões. Para obter mais informações, consulte NamedWaitHandleOptions.
Confira também
Aplica-se a
Mutex(Boolean, String, Boolean, MutexSecurity)
Inicializa uma nova instância da Mutex classe com um valor booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex, uma variável booliana que, quando o método retorna, indica se o thread de chamada recebeu a propriedade inicial do mutex e a segurança de controle 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 fornecer a propriedade inicial do thread de chamada do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado dessa chamada; caso contrário, false.
- name
- String
O nome, se o objeto de sincronização deve ser compartilhado com outros processos; caso contrário, null ou uma cadeia de caracteres vazia. O nome diferencia maiúsculas de minúsculas. O caractere de barra invertida (\) é reservado e só pode ser usado para especificar um namespace. Para obter mais informações sobre namespaces, consulte a seção comentários. Pode haver mais restrições ao nome dependendo do sistema operacional. Por exemplo, em sistemas operacionais baseados em Unix, o nome após a exclusão do namespace deve ser um nome de arquivo válido.
- createdNew
- Boolean
Quando esse método é retornado, contém um booliano que é true se um mutex local foi criado (ou seja, se name é null ou uma cadeia de caracteres vazia) ou se o mutex do sistema nomeado especificado foi criado; false se o mutex do sistema nomeado especificado já existia. Esse parâmetro é passado sem inicialização.
- mutexSecurity
- MutexSecurity
Um MutexSecurity objeto que representa a segurança do controle de acesso a ser aplicado ao mutex do sistema nomeado.
- Atributos
Exceções
name é inválido. Isso pode ser por vários motivos, incluindo algumas restrições que podem ser colocadas pelo sistema operacional, como um prefixo desconhecido ou caracteres inválidos. Observe que o nome e os prefixos comuns "Global\" e "Local\" diferenciam maiúsculas de minúsculas.
- ou -
Houve outro erro. A HResult propriedade pode fornecer mais informações.
Windows somente: name especificado um namespace desconhecido. Consulte Nomes de Objetos para obter mais informações.
O name é muito longo. As restrições de comprimento podem depender do sistema operacional ou da configuração.
O mutex nomeado existe e tem segurança de controle de acesso, mas o usuário não tem FullControl.
Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de um tipo diferente pode ter o mesmo nome.
.NET Framework somente: name é maior que MAX_PATH (260 caracteres).
Exemplos
O exemplo de código a seguir demonstra o comportamento entre processos de um mutex nomeado com segurança de controle de acesso. O exemplo usa a sobrecarga do OpenExisting(String) método para testar a existência de um mutex nomeado.
Se o mutex não existir, ele será criado com a propriedade inicial e a segurança de controle de acesso que nega ao usuário atual o direito de usar o mutex, mas concede o direito de ler e alterar permissões no mutex.
Se você executar o exemplo compilado de duas janelas de comando, a segunda cópia gerará uma exceção de violação de acesso na chamada para OpenExisting(String). A exceção é capturada e o exemplo usa a sobrecarga do OpenExisting(String, MutexRights) método para abrir o mutex com os direitos necessários para ler e alterar as permissões.
Depois que as permissões são alteradas, o mutex é aberto com os direitos necessários para inseri-lo e liberá-lo. Se você executar o exemplo compilado de uma terceira janela de comando, ele será 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
Comentários
Pode name ser prefixado com Global\ ou Local\ para especificar um namespace. Quando o Global namespace é especificado, o objeto de sincronização pode ser compartilhado com todos os processos no sistema. Quando o Local namespace é especificado, que também é o padrão quando nenhum namespace é especificado, o objeto de sincronização pode ser compartilhado com processos na mesma sessão. No Windows, uma sessão é uma sessão de logon e os serviços normalmente são executados em uma sessão não interativa diferente. Em sistemas operacionais semelhantes ao Unix, cada shell tem sua própria sessão. Os objetos de sincronização local de sessão podem ser apropriados para sincronizar entre processos com uma relação pai/filho em que todos eles são executados na mesma sessão. Para obter mais informações sobre nomes de objetos de sincronização no Windows, consulte Object Names.
Se um name for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente será usado. Se um objeto de sincronização de um tipo diferente já existir no namespace, um WaitHandleCannotBeOpenedException será gerado. Caso contrário, um novo objeto de sincronização será criado.
Se name não null for e initiallyOwned for true, o thread de chamada será proprietário do mutex nomeado somente se createdNew estiver true após a chamada. Caso contrário, o thread poderá solicitar o mutex chamando o WaitOne método.
Use esse construtor para aplicar a segurança de controle de acesso a um mutex do sistema nomeado quando ele for criado, impedindo que outro código assumisse o controle do mutex.
Esse construtor inicializa um Mutex objeto que representa um mutex de sistema nomeado. Você pode criar vários Mutex objetos que representam o mesmo mutex do sistema nomeado.
Se o mutex do sistema nomeado não existir, ele será criado com a segurança de controle de acesso especificada. Se o mutex nomeado existir, a segurança de controle de acesso especificada será ignorada.
Note
O chamador tem controle total sobre o objeto recém-criado Mutex , mesmo que mutexSecurity negue ou não conceda alguns direitos de acesso ao usuário atual. No entanto, se o usuário atual tentar obter outro objeto Mutex para representar o mesmo mutex nomeado, usando um construtor ou o método OpenExisting, Windows segurança de controle de acesso será aplicada.
Se o mutex nomeado já tiver sido criado com segurança de controle de acesso e o chamador não tiver MutexRights.FullControl, uma exceção será gerada. Para abrir um mutex nomeado existente com apenas as permissões necessárias para sincronizar atividades de thread, consulte o OpenExisting método.
Se você especificar null ou uma cadeia de caracteres vazia para name, um mutex local será criado, como se você tivesse chamado o Mutex(Boolean) construtor. Nesse caso, createdNew é sempre true.
Como eles são de todo o sistema, mutexes nomeados podem ser usados para coordenar o uso de recursos entre os limites do processo.
Note
Em um servidor que está executando os Serviços de Terminal, um mutex de sistema nomeado pode ter dois níveis de visibilidade. Se seu nome começar com o prefixo Global\, o mutex ficará visível em todas as sessões do servidor de terminal. Se seu nome começar com o prefixo Local\, o mutex ficará visível apenas na sessão do servidor terminal em que foi criado. Nesse caso, um mutex separado com o mesmo nome pode existir em cada uma das outras sessões de servidor de terminal no servidor. Se você não especificar um prefixo ao criar um mutex nomeado, ele usará o prefixo Local\. Em uma sessão de servidor terminal, dois mutexes cujos nomes diferem apenas por seus prefixos são mutexes separados e ambos são visíveis para todos os processos na sessão do servidor terminal. Ou seja, os nomes Global\ de prefixo e Local\ descrevem o escopo do nome mutex em relação às sessões do servidor terminal, não em relação aos processos.
Caution
Por padrão, um mutex nomeado não é restrito ao usuário que o criou. Outros usuários podem ser capazes de abrir e usar o mutex, incluindo interferir com o mutex inserindo o mutex e não saindo dele. Para restringir o acesso a usuários específicos, você pode passar um MutexSecurity ao criar o mutex nomeado. Evite usar mutexes nomeados sem restrições de acesso em sistemas que podem ter usuários não confiáveis executando código.
A barra invertida (\) é um caractere reservado em um nome mutex. Não use uma barra invertida (\) em um nome mutex, exceto conforme especificado na observação sobre como usar mutexes em sessões de servidor de terminal. Caso contrário, um DirectoryNotFoundException pode ser gerado, mesmo que o nome do mutex represente um arquivo 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 booliano que indica se o thread de chamada deve ter a propriedade inicial do mutex, uma cadeia de caracteres que é o nome do mutex, opções para definir o escopo do usuário e o acesso ao escopo da sessão e um valor booliano que, quando o método retorna, indica se o thread de chamada 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 fornecer a propriedade inicial do thread de chamada do mutex do sistema nomeado se o mutex do sistema nomeado for criado como resultado dessa chamada; caso contrário, false.
- name
- String
O nome, se o objeto de sincronização deve ser compartilhado com outros processos; caso contrário, null ou uma cadeia de caracteres vazia. O nome diferencia maiúsculas de minúsculas.
- options
- NamedWaitHandleOptions
As opções de escopo para o mutex do sistema nomeado. O padrão é acessar apenas o usuário atual e a sessão atual. As opções especificadas podem afetar o namespace para o nome e o acesso ao objeto mutex do sistema subjacente.
- createdNew
- Boolean
Quando esse método é retornado, contém um booliano que é true se um mutex local foi criado (ou seja, se name é null ou uma cadeia de caracteres vazia) ou se o mutex do sistema nomeado especificado foi criado; contém false se o mutex do sistema nomeado especificado já existia. Esse parâmetro é passado sem inicialização.
Exceções
O mutex nomeado existe e tem segurança de controle de acesso, mas o usuário não tem FullControl.
name é inválido. Isso pode ser por vários motivos, incluindo algumas restrições que podem ser colocadas pelo sistema operacional, como um prefixo desconhecido ou caracteres inválidos. Observe que o nome e os prefixos comuns "Global\" e "Local\" diferenciam maiúsculas de minúsculas.
- ou -
Houve outro erro. A HResult propriedade pode fornecer mais informações.
Windows somente: name especificado um namespace desconhecido. Consulte Nomes de Objetos para obter mais informações.
O name é muito longo. As restrições de comprimento podem depender do sistema operacional ou da configuração.
Um objeto de sincronização com o fornecido name não pode ser criado. Um objeto de sincronização de um tipo diferente pode ter o mesmo nome.
- ou -
Um objeto com o especificado name existe, mas os especificados options não são compatíveis com as opções do objeto existente.
Comentários
Se um name objeto de sincronização for fornecido e um objeto de sincronização do tipo solicitado já existir no namespace, o objeto de sincronização existente será usado, no entanto, se options especificar o acesso limitado ao usuário atual e o objeto de sincronização não for compatível com ele, um WaitHandleCannotBeOpenedException será gerado. Se um objeto de sincronização de um tipo diferente já existir no namespace, um WaitHandleCannotBeOpenedException também será gerado. Caso contrário, um novo objeto de sincronização será criado.
Se name não null for e initiallyOwned for true, o thread de chamada será proprietário do mutex nomeado somente se createdNew estiver true após a chamada. Caso contrário, o thread poderá solicitar o mutex chamando o WaitOne método.
Esse construtor inicializa um Mutex objeto que representa um mutex de sistema nomeado. Você pode criar vários Mutex objetos que representam o mesmo mutex do sistema nomeado.
Se o mutex nomeado já tiver sido criado com segurança de controle de acesso e o chamador não tiver MutexRights.FullControl direitos, uma exceção será gerada. Para abrir um mutex nomeado existente com apenas as permissões necessárias para sincronizar atividades de thread, consulte o OpenExisting método.
Se você especificar null ou uma cadeia de caracteres vazia para name, um mutex local será criado, como se você tivesse chamado o Mutex(Boolean) construtor. Nesse caso, createdNew é sempre true.
Como eles são de todo o sistema, mutexes nomeados podem ser usados para coordenar o uso de recursos entre os limites do processo.
O options parâmetro pode ser fornecido para especificar se o mutex nomeado está acessível somente ao usuário atual ou a todos os usuários. Ele também permite que você especifique se o mutex nomeado está acessível apenas para processos na sessão atual ou para todas as sessões. Para obter mais informações, consulte NamedWaitHandleOptions.