- 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/
我试图了解是否有可能采用构成另一个 protobuf 一部分的序列化 protobuf 并将它们合并在一起而不必反序列化第一个 protobuf。 例如,给定一个 protobuf 包装器: synt
正如我最近发现的,我们可以使用两个类 ProtoBuf.Serializer 和 ProtoBuf.Meta.TypeModel 在 protobuf-net 中序列化/反序列化。例如,假设我们有一个
我正在尝试使用 protobuf 序列化我的下面的类,但它因“对象引用”错误而失败。更多详情如下。通过查看错误详细信息,您知道会出现什么问题吗?注意:我的用户对象太大了,它有太多的子对象和属性。所以不
我想识别要反序列化的文件是否是protobuf序列化的。这是因为我想提供不止一种选项来为用户序列化和反序列化文件。我正在使用 protobuf.net 序列化为 protobuf 格式。 最佳答案 不
我已经使用位于 https://protogen.marcgravell.com/ 的工具构建了我的 C# 类来自 https://developers.google.com/transit/gtfs
有一个通过 UDP 接受消息的 Go 服务器。使用这种设计,它只能扫描一种特定类型的实体,world.Entity . for { buf := make([]byte, 10
比如我想序列化和反序列化System.Drawing.Font这是不可变的,不能更改以适应 protobuf-net 约定。一般来说,是否可以在 protobuf-net 中编写某种“自定义”序列化程
我开始用 protobuf 2.2.0 构建一个应用程序,因为它是最新的。现在我正在考虑升级到最新的 protobuf 2.4.0a。 如果我这样做,对于同一架构,一个版本的应用程序生成的消息是否仍然
在我从 BinaryFormatter 切换到 protobuf-net 的过程中, 我在序列化集合时观察到了差异。 在下面的代码示例中,反序列化(protobuf-net v2r470)返回 如果在
知道正在发送的 protobuf 消息类型的 API 是什么? 例如,我使用以下方法获取 SendNameMessage 对象。 SendNameMessage sendNameObj = Seria
我在我们的一个项目中使用 protobuf-net 来序列化/反序列化一大组同类对象。它运行良好,速度非常快。不过只有一个问题。反序列化时是否可以使用 linq(或任何其他机制)指定过滤条件,以便加载
我正在尝试使用 protobuf-net 序列化一些对象,但不幸的是他们自由地使用了 DateTimeOffset , protobuf-net 尚不支持。这导致了很多: No serializer
我在 ionic2 项目中使用 protobuf.js。我有一个有效的 .proto 文件,我首先将其转换为静态 javascript 文件: pbjs -t static databaseapi.p
我通过 vcpkg vcpkg install protobuf:x64-windows 安装了 protobuf .显然它安装了最新版本(3.6.1)。对于我需要版本<=3.5.1的项目。有没有办法
我有以下类(class):- [Serializable] [DataContract(Name = "StateValueWrapper")] public class StateValueWrap
protobuf net 似乎不支持列表/数组的 AsReference 以及列表/数组内对象的 AsReference。这会在最终的 v2 中得到支持吗? [ProtoMember(1, AsRef
我正在使用 protobuf-net 来序列化和反序列化我的消息。我的消息还包含可以为空的字符串。但是,当我在另一侧反序列化它们时,我得到空字符串 ("")。 根据谷歌文档,空字符串中字符串类型的默认
我已经阅读了有关继承的各种帖子,并且 Protocol Buffer 不支持继承。我不想继承 Protocol Buffers 消息,而是继承,这样我就可以轻松处理我的所有 Protocol Buff
我知道带有 protobuf.net 的列表不支持 AsReference,因此我尝试了解决此限制的方法。我创建了一个名为 SuperList 的自定义列表,其中包含包装在 SuperListItem
我正在尝试使用 ProtoMember 中的 AsReference 选项进行递归引用。如果我使用公共(public)构造函数创建 AnOwner 然后序列化/反序列化,AnOwner.Data 变为
我是一名优秀的程序员,十分优秀!