Udostępnij za pośrednictwem


SYSLIB0054: Element Thread.VolatileRead i Thread.VolatileWrite są przestarzałe

Wszystkie przeciążenia Thread.VolatileRead metod i Thread.VolatileWrite są przestarzałe, począwszy od platformy .NET 9. Wywołanie ich w kodzie generuje ostrzeżenie SYSLIB0054 w czasie kompilacji.

Przyczyna obsoletionu

Implementacja programu .NET Framework przeciążeń 64-bitowych Thread.VolatileRead metod i Thread.VolatileWrite miała niepoprawną niepodzielność. W programie .NET (Core) implementacja została zmieniona, aby delegować odpowiednio do Volatile.Read elementów i Volatile.Write, co zapewnia właściwą semantykę pozyskiwania/wydawania. Ponadto metody w Thread klasie nie zawierają przeciążenia, które akceptuje argument logiczny, podczas gdy Volatile metody działają. Metody zostały przestarzałe, aby zachęcić do korzystania z Volatile metod.

Rozwiązanie

Wywołaj Volatile.Read lub Volatile.Write zamiast tego.

Pomijanie ostrzeżenia

Jeśli musisz używać przestarzałych interfejsów API, możesz pominąć ostrzeżenie w kodzie lub w pliku projektu.

Aby pominąć tylko jedno naruszenie, dodaj dyrektywy preprocesora do pliku źródłowego, aby wyłączyć, a następnie ponownie włączyć ostrzeżenie.

// Disable the warning.
#pragma warning disable SYSLIB0054

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

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

Aby pominąć wszystkie SYSLIB0054 ostrzeżenia w projekcie, dodaj <NoWarn> właściwość do pliku projektu.

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

Aby uzyskać więcej informacji, zobacz Pomijanie ostrzeżeń.