Partilhar via


SYSLIB0054: Thread.VolatileRead e Thread.VolatileWrite estão obsoletos

Todas as sobrecargas dos Thread.VolatileRead métodos e Thread.VolatileWrite são obsoletas, começando no .NET 9. Chamá-los em código gera aviso SYSLIB0054 em tempo de compilação.

Motivo da obsolescência

A implementação do .NET Framework das sobrecargas de 64 bits dos Thread.VolatileRead métodos e Thread.VolatileWrite tinha atomicidade incorreta. No .NET (Core), a implementação foi alterada para delegar ao Volatile.Read e Volatile.Write, respectivamente, que fornecem semântica de aquisição/liberação adequada. Além disso, os Thread métodos na classe não incluem uma sobrecarga que aceita um argumento booleano, enquanto os Volatile métodos fazem. Os métodos foram obsoletos para incentivar o Volatile uso dos métodos.

Solução

Ligue Volatile.Read ou Volatile.Write em vez disso.

Suprimir um aviso

Se você precisar usar as APIs obsoletas, poderá suprimir o aviso no código ou no arquivo de projeto.

Para suprimir apenas uma única violação, adicione diretivas de pré-processador ao arquivo de origem para desativar e reativar o aviso.

// Disable the warning.
#pragma warning disable SYSLIB0054

// Code that uses obsolete API.
// ...

// Re-enable the warning.
#pragma warning restore SYSLIB0054

Para suprimir todos os SYSLIB0054 avisos em seu projeto, adicione uma <NoWarn> propriedade ao seu arquivo de projeto.

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   ...
   <NoWarn>$(NoWarn);SYSLIB0054</NoWarn>
  </PropertyGroup>
</Project>

Para obter mais informações, consulte Suprimir avisos.