“部分是,部分不是”。
protobuf-net 没有关于命名元组的特定知识,the names are not available to library code,但从 v2.2.0 开始,protobuf-net 能够推断ValueTuple<...> 类型,本质上将其视为位置类型 - 所以 Bid 将是字段 1,Ask 将是字段 2,等等。像 GetProto<T> 这样的一些代码将不会产生结果您期望(因为 a:它看不到名称,并且 b:对于大型元组,形状变得非常奇怪),并且您将无法控制细粒度的序列化细节(DataFormat 等),但是: 应该可以的。
以下工作正常:
using ProtoBuf;
using System.Collections.Generic;
static class P
{
static void Main()
{
var obj = new MyType { FuturesCurveData = {
{ 1.0, (1, 2, 3, 4, 5, 6, 7, 8) },
{ 2.0, (2, 3, 4, 5, 6, 7, 8, 9) },
} };
var clone = Serializer.DeepClone(obj);
foreach(var pair in clone.FuturesCurveData)
{
System.Console.WriteLine($"{pair.Key}: {pair.Value}");
}
}
}
[ProtoContract]
class MyType
{
[ProtoMember(1)]
public SortedDictionary<double, (double Bid, double Ask, double Open, double High, double Low, double Close, int Volume, int OpenInt)> FuturesCurveData { get; } =
new SortedDictionary<double, (double Bid, double Ask, double Open, double High, double Low, double Close, int Volume, int OpenInt)>();
}
输出:
1: (1, 2, 3, 4, 5, 6, 7, 8)
2: (2, 3, 4, 5, 6, 7, 8, 9)
这就是GetProto<MyType>() 产生的结果——不太成功:
syntax = "proto2";
package System;
message KeyValuePair_Double_ValueTuple_Double_Double_Double_Double_Double_Double_Int32_ValueTuple_Int32 {
optional double Key = 1;
optional ValueTuple_Double_Double_Double_Double_Double_Double_Int32_ValueTuple_Int32 Value = 2;
}
message MyType {
repeated KeyValuePair_Double_ValueTuple_Double_Double_Double_Double_Double_Double_Int32_ValueTuple_Int32 FuturesCurveData = 1;
}
message ValueTuple_Double_Double_Double_Double_Double_Double_Int32_ValueTuple_Int32 {
optional double Item1 = 1;
optional double Item2 = 2;
optional double Item3 = 3;
optional double Item4 = 4;
optional double Item5 = 5;
optional double Item6 = 6;
optional int32 Item7 = 7;
optional ValueTuple_Int32 Rest = 8;
}
message ValueTuple_Int32 {
optional int32 Item1 = 1;
}
附带说明,如果密钥类型为int 或string,它应该作为map<,> 工作,但它似乎遇到了一个错误,即I have logged。