- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已阅读 Protobuf-net memcache provider fails on append/set ArraySegment这表示它可能在某些时候得到支持。
我也试过那个问题提示的测试,2.0.0.668版本不支持。
有没有人成功地将 ArraySegments 与 protobuf-net 结合使用,或者对通过网络发送字节数组的有效方法有想法。
即我有一个这样的对象:
[ProtoContract]
class Foo
{
[ProtoMember(1)]
public byte[] Data { get; set; }
}
我想将一个不同的对象 T 序列化为一个字节数组,将其分配给 Data,然后将 Foo 序列化为另一个 byte[]。 (听起来效率低下,但 Foo 类必须与类型无关,它可以是通用的吗?)。
关键是我更愿意尽量减少分配/GC,所以我想在每次序列化数据时尽量减少数组的复制或新数组的分配。
下面是一些示例代码,演示了我正在努力更有效地实现的目标:
public class DataSender<T>
{
private ISerializer serializer; //Could be any kind of binary serializer
public void Send(T obj)
{
MemoryStream serializationBuffer = new MemoryStream(); // Inefficent allocation
serializer.Serialize(serializationBuffer, obj);
var sendable = new Foo(){ Data=serializationBuffer.ToArray() } // Inefficent copy
Sender.Send(sendable);
}
}
非常欢迎任何关于替换我的 Foo 对象和/或发送代码的建议。
最佳答案
我觉得这太复杂了。我认为您使 Foo
通用的想法非常好,因此您可以:
[ProtoContract]
class Foo<T>
{
[ProtoMember(1)]
public T Data { get; set; }
}
然后您将使用如下简单代码实例化一个新对象:
var foo = new Foo<Bar>() { Data = new Bar() { Data = "Some Data" } };
但是,根据您的附加评论,您不能保证该对象是可序列化的,或者具有原型(prototype)属性。例如 bar 类可能如下所示:
class Bar
{
public string Data { get; set; }
}
在这种情况下,您可以使用 RuntimeTypeModel
类在运行时配置序列化。
下面是一个使用 protobuf 对数据对象进行动态运行时配置的完整序列化和反序列化的示例:
using (var serializationBuffer = new MemoryStream())
{
var foo = new Foo<Bar>() { Data = new Bar() { Data = "Some Data" } };
RuntimeTypeModel.Default.Add(foo.Data.GetType(), false)
.Add(foo.GetType().GetProperties().Select(p => p.Name).ToArray());
Serializer.Serialize(serializationBuffer, foo);
serializationBuffer.Seek(0, SeekOrigin.Begin);
var deserialized = Serializer.Deserialize<Foo<Bar>>(serializationBuffer);
}
这样您就可以使用任何对象作为您的数据对象,即使它没有序列化属性。但是,您将受到性能 的惩罚,因为使用反射来发现类型属性。但是,您应该获得所需的灵 active 。
使用 WCF 通过网络发送此对象的正确方法是使用 protobuf ProtoEndpointBehavior
配置 WCF 自定义行为,然后 WCF 将使用 protobuf 自动序列化和反序列化您的 Foo 对象。这意味着客户端只需确保它使用的是用 proto 属性装饰的对象,然后通过网络发送它们。 WCF 将负责序列化/反序列化。
这是一个如何使用 WCF protobuf 服务的综合示例:
http://www.drdobbs.com/windows/working-with-protobuf-wcf-services/240159282?pgno=1
通过网络发送数据的效率取决于许多因素。如果您通过线路发送大对象,您可以将 WCF TransferMode
设置为使用 Streaming,然后在另一端读取字节数组 block 中的数据。
但是,效率是您应该衡量而不是假设的东西。
关于c# - protobuf-net 是否支持 ArraySegment(还?),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26503602/
.NET 中的 Socket 类公开了以下方法: Socket.BeginSend Method (IList>, SocketFlags, AsyncCallback, Object) 我有一个返回
我一直在寻找方法来返回基本上由 ArraySegment 在偏移量和计数方面持有的段。尽管 ArraySegment 拥有完整的原始数组,但它只是将其分隔,因为对段的任何更改都会反射(reflect)
我刚刚遇到 ArraySegment在子类化 MessageEncoder 时键入类。 我现在明白它是给定数组的一段,有一个偏移量,不可枚举,也没有索引器,但我仍然不明白它的用法。有人可以举例说明吗?
我刚刚查看了 .NET Core 中的 ArraySegment 类 (...\microsoft.netcore.app\2.0.0\ref\netcoreapp2.0\System .Runtim
bool MemoryStream.TryGetBuffer(out ArraySegment buffer) 是 .NET 4.6 中的一个新 API,可用于访问存储在 MemoryStream 中
传递 ArraySegment 的列表 背后的原因是什么?至 Socket.BeginReceive/SocketAsyncEventArgs ? MSDN for the Socket.BeginR
我已阅读 Protobuf-net memcache provider fails on append/set ArraySegment这表示它可能在某些时候得到支持。 我也试过那个问题提示的测试,2
我想解决这个问题, 我想使用 ArraySegment 传输 Json 对象 我的 JSON 数据是以这种格式 {"employees":[ {"firstName":"John", "las
我正在研究返回的最佳方式' views ' 放入一个非常大的数组中,发现 ArraySegment这完全符合我的需求。然而,我随后发现 Memory这似乎表现得一样,除了需要一个跨度来查看内存。 对于
随着 C# 7.2 中 Memory、Span 和 ArraySegment 的引入,我想知道是否可以将非托管数组表示为可枚举数组对象,存在于堆中。 后一个要求排除了 Span,它基本上实现了我想要的
我一直在寻找实现一个自定义类: IList> 这将被传递给一个套接字,并用作从该套接字接收数据的缓冲区。 Socket.BeginReceive( IList>, SocketFlags, A
我知道我可以通过 IList 进行枚举,例如: public byte[] ConvertToByteArray(IList> list) { IList newList = new List
我无法概念化 the new Span in C# 的用法. 它取代了什么结构? ArraySegment 现在过时了吗? 它启用了哪些以前没有的功能? Span 是 C# 数组的有效替代品吗?哪些情
我是一名优秀的程序员,十分优秀!