我正在序列化一个流,它正在使用REST服务存储在云中。 序列化部分如下-
public void serialize(Object obj, Stream str)
{
using (GZipStream zipStream = new GZipStream(str, CompressionMode.Compress, true))
{
if (obj is Stream)//This is executed in my case
{
((Stream)obj).CopyTo(zipStream);
}
else
{
binarySerializer.serialize(obj, zipStream);
}
}
}
参数obj是流内容,str是一个空流,它存储序列化流以供进一步使用。如果条件在我的情况下执行,因为obj是一个流。
这是二进制序列化器.序列化((代码 -
public void serialize(object obj, Stream str)
{
if (obj is Stream)
{
((Stream)obj).CopyTo(str);
}
else
{
BinaryFormatter formatter = new BinaryFormatter();
formatter.Serialize(str, obj);
}
}
这工作正常,我能够使用Restlet 客户端chrome 扩展名从云下载序列化文件(显示为带有下载选项的二进制文件(。
谁能帮我写反序列化部分? 我想要带有以下签名的反序列化代码 -
public T deserialize<T>(Stream str)
{
//Code here
}
提前感谢!
如果我不相信你对,你可以这样写
public T deserialize<T>(Stream str) where T : class, new()
{
Type type = typeof(T);
if (type == typeof(Stream))
{
using (var bigStr = new GZipStream(str, CompressionMode.Decompress))
using (var outStream = new MemoryStream())
{
bigStr.CopyTo(outStream);
return outStream as T;
}
}
else
{
BinaryFormatter bin = new BinaryFormatter();
return (T)bin.Deserialize(str);
}
}
如果T
是一种Stream
,我们将反序列化GZipStream
Stream
。其他情况我们使用的是简单的二进制格式化程序。
评论中的注释后
public T Deserialize<T>(Stream str)
{
Type type = typeof(T);
if (type == typeof(Stream))
{
using (var bigStr = new GZipStream(str, CompressionMode.Decompress))
using (var outStream = new MemoryStream())
{
bigStr.CopyTo(outStream);
return (T)(outStream as object);
}
}
else
{
BinaryFormatter bin = new BinaryFormatter();
return (T)bin.Deserialize(str);
}
}
为了从函数返回结果,我们首先从MemoryStream
类型转换为object
类型,然后我们可以使用从object
类型到T
类型的显式转换。