gpt4 book ai didi

c# - 在哪里最好存储临时反序列化数据?

转载 作者:行者123 更新时间:2023-11-30 19:44:28 25 4
gpt4 key购买 nike

我能否避免向类中添加额外的字段来存储仅在反序列化/序列化时需要的数据?

假设我有一些类(class):

[Serializable]
class MyClass {
[NonSerialized]
NonSerializableDataType myField;

SomeOtherDataType serializableTemporaryData;

[OnSerializing]
OnSerializing (StreamingContext context) {
// build serializableTemporaryData from myField
}

[OnDeserialized]
void OnDeserialized (StreamingContext context) {
// build myField from serializableTemporaryData
}
}

有什么方法可以避免 MyClass 的每个对象中都有 serializableTemporaryData 字段吗?例如,我可以将其设为静态(可能通过更改我的 On... 方法)吗?

约束:我无法更改 NonSerializableDataType 的实现。

示例:假设 myField 包含资源句柄。然后,在序列化时,我必须存储一些关于反序列化后如何获取资源的信息,但我不能存储句柄本身。如果我将句柄包装到另一个类中,那么我只是将问题转移到包装类中——然后我会为包装类问同样的问题。

最佳答案

如果你需要控制序列化过程,你应该实现ISerialization接口(interface)。

[Serializable]
public class MyClass: ISerializable
{
// As you are in control of serialization process now
// [Serialized] and [NonSerialized] attributes are no longer required
private NonSerializableDataType myField;

public virtual void GetObjectData(SerializationInfo info, StreamingContext context)
{
// Create and populate your SomeOtherDataType local variable here, then push it into info variable
// Or even better, dont create SomeOtherDataType, just put additional serialization data into info variable, for example:
info.AddValue("URL", "http://this.way.com");
}

protected MyClass(SerializationInfo info, StreamingContext context)
{
// Dont forget to define constructor for deserialization purpose

this.myField = new NonSerializableDataType(loadFromURL: (string)info.GetValue("URL", typeof(string)));
}
}

没有仅用于序列化数据的额外类,没有字段污染。唯一的潜在问题是监视从此类派生的任何可序列化数据(如果需要,覆盖 GetObjectData(...))。

更多信息:MSDN ISerializable

关于c# - 在哪里最好存储临时反序列化数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12329872/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com