gpt4 book ai didi

c# - ISerializable:在反序列化时分配现有对象

转载 作者:太空狗 更新时间:2023-10-30 00:58:15 25 4
gpt4 key购买 nike

我们的任务非常简单,我们有一个对象图,其中每个对象 (IDItem) 都有一个唯一的 ID。对象图存在两次,在客户端和服务器机器上。

现在我们将一些可序列化的命令传递给服务器。该命令具有一些 IDItem 作为字段。 IDItems 实现了 ISerializable 接口(interface),并且只将它们的 ID 存储在 SerializationInfo 中。喜欢:

// The method called when serializing a IDItem.
void GetObjectData(SerializationInfo info, StreamingContext context)
{
// Instead of serializing this object, just save the ID
info.AddValue("ID", this.GetID());
}

问题是,我们如何将现有对象分配给反序列化器创建的实例?显然 ISerializable 构造函数中的以下内容不起作用,因为“this”标识符是只读的:

//does not work   
protected IDItem(SerializationInfo info, StreamingContext context)
{
this = GlobalObject.GetIDItem(info.GetString("ID"));
}

那么知道如何将现有对象分配给反序列化对象吗?

最好的问候,

最佳答案

可能可以通过创建一个实现 IObjectReference 的代理对象来做到这一点并执行假的反序列化。

(您的代理对象需要同时存在于客户端和服务器上,我想您的类型版本控制等也需要在两者上完全相同。)

[Serializable]
public class Example : ISerializable
{
// ...

void ISerializable.GetObjectData(
SerializationInfo info, StreamingContext context)
{
info.SetType(typeof(ExampleDeserializationProxy));
info.AddValue("ID", this.GetID());
}
}

// ...

[Serializable]
public class ExampleDeserializationProxy : IObjectReference, ISerializable
{
private readonly int _id;

private ExampleDeserializationProxy(
SerializationInfo info, StreamingContext context)
{
_id = info.GetInt32("ID");
}

object IObjectReference.GetRealObject(StreamingContext context)
{
return GlobalObject.GetIDItem(_id);
}

void ISerializable.GetObjectData(
SerializationInfo info, StreamingContext context)
{
throw new NotSupportedException("Don't serialize me!");
}
}

关于c# - ISerializable:在反序列化时分配现有对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3213410/

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