SYSLIB0054: Thread.VolatileRead と Thread.VolatileWrite は古い形式です

.NET 9 以降では、Thread.VolatileRead および Thread.VolatileWrite メソッドのすべてのオーバーロードは古い形式となっています。 これらをコードで呼び出すと、コンパイル時に警告 SYSLIB0054 が生成されます。

廃止の理由

.NET Framework 実装における Thread.VolatileRead および Thread.VolatileWrite メソッドの 64 ビット オーバーロードには誤った原子性が存在していました。 .NET (Core) において、この実装は、それぞれ適切な取得/リリースのセマンティクスを提供する Volatile.Read および Volatile.Write へ委任されるように変更されました。 さらに、Thread クラス内のこれらのメソッドは、ブール型の引数を受け取るオーバーロードを含んでいませんが、Volatile メソッドはこれを含んでいます。 これらのメソッドは、Volatile の使用を推奨するために旧形式化されました。

回避策

代わりに Volatile.Read または Volatile.Write を呼び出します。

警告を抑制する

古い API を使う必要がある場合は、コードまたはプロジェクト ファイルで警告を抑制することができます。

単一の違反だけを抑制するには、ソース ファイルにプリプロセッサ ディレクティブを追加して警告を無効にしてから、再度有効にします。

// Disable the warning.
#pragma warning disable SYSLIB0054

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

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

プロジェクトですべての SYSLIB0054 警告を抑制するには、プロジェクト ファイルに <NoWarn> プロパティを追加します。

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

詳細については、「警告を表示しない」を参照してください。