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>
詳細については、「警告を表示しない」を参照してください。
.NET