SYSLIB0050: フォーマッタベースのシリアル化は廃止されました
.NET 8 以降では、次の API は廃止されています。 これらをコードで呼び出すと、コンパイル時に警告 SYSLIB0050
が生成されます。
- System.Runtime.Serialization.FormatterConverter
- System.Runtime.Serialization.FormatterServices
- System.Runtime.Serialization.IFormatterConverter
- System.Runtime.Serialization.IObjectReference
- System.Runtime.Serialization.ISafeSerializationData
- System.Runtime.Serialization.ISerializationSurrogate
- System.Runtime.Serialization.ISurrogateSelector
- System.Runtime.Serialization.ObjectIDGenerator
- System.Runtime.Serialization.ObjectManager
- System.Runtime.Serialization.SafeSerializationEventArgs
- System.Runtime.Serialization.SerializationObjectManager
- System.Runtime.Serialization.StreamingContextStates
- System.Runtime.Serialization.SurrogateSelector
- System.Runtime.Serialization.Formatters.FormatterAssemblyStyle
- System.Runtime.Serialization.Formatters.FormatterTypeStyle
- System.Runtime.Serialization.Formatters.IFieldInfo
- System.Runtime.Serialization.Formatters.TypeFilterLevel
- System.Type.IsSerializable
- System.Reflection.FieldAttributes.NotSerialized
- System.Reflection.FieldInfo.IsNotSerialized
- System.Reflection.TypeAttributes.Serializable
- System.Runtime.Serialization.ISerializable.GetObjectData(SerializationInfo, StreamingContext)
- SerializationInfo(Type, IFormatterConverter, Boolean)
- SerializationInfo(Type, IFormatterConverter)
- StreamingContext(StreamingContextStates, Object)
- StreamingContext(StreamingContextStates)
回避策
FormatterServices.GetUninitializedObject(Type) を使用してい場合は、代わりに RuntimeHelpers.GetUninitializedObject(Type) を使用してください。
.NET Framework と最新の .NET 用にクロスコンパイルする場合は、次のスニペットに示すように、
#if
ステートメントを使用して、適切な API を選択的に呼び出すことができます。Type typeToInstantiate; #if NET5_0_OR_GREATER object obj = System.Runtime.CompilerServices.RuntimeHelpers.GetUninitializedObject(typeToInstantiate); #else object obj = System.Runtime.Serialization.FormatterServices.GetUninitializedObject(typeToInstantiate); #endif
シリアル化ライブラリを作成する場合、レガシ シリアル化インフラストラクチャ (
[Serializable]
とISerializable
) はサポートしないことを強くお勧めします。 最新のシリアル化ライブラリには、プライベート実装の詳細ではなく、型のパブリック API に基づくポリシーが必要です。 シリアライザーをこれらの実装の詳細に基づくものとし、シリアル化されたペイロード内に型名を埋め込むよう促すISerializable
や他のメカニズムと強く結び付ける場合は、「BinaryFormatter および関連する型を使用するときの逆シリアル化のリスク」で説明されている問題が発生する可能性があります。シリアル化ライブラリと従来のシリアル化インフラストラクチャとの互換性を維持する必要がある場合は、レガシ シリアル化 API の廃止を簡単に抑制できます。
警告を抑制する
古い API を使う必要がある場合は、コードまたはプロジェクト ファイルで警告を抑制することができます。
単一の違反だけを抑制するには、ソース ファイルにプリプロセッサ ディレクティブを追加して警告を無効にしてから、再度有効にします。
// Disable the warning.
#pragma warning disable SYSLIB0050
// Code that uses obsolete API.
// ...
// Re-enable the warning.
#pragma warning restore SYSLIB0050
プロジェクトですべての SYSLIB0050
警告を抑制するには、プロジェクト ファイルに <NoWarn>
プロパティを追加します。
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
...
<NoWarn>$(NoWarn);SYSLIB0050</NoWarn>
</PropertyGroup>
</Project>
詳細については、「警告を表示しない」を参照してください。
関連項目
.NET