用于多重继承的proto文件



这是我的类建模方式。抱歉太长了:

[Serializable]
[DataContract]
public class RequestSection
{
    [DataMember(Order = 1)]
    public List<BaseA> Allrequests;
    public RequestSection()
    {
        Allrequests = new List<BaseA>();
    }
}
[Serializable]
[DataContract]
[ProtoInclude(2, typeof(BaseA<derResponse1>))]
[ProtoInclude(3, typeof(BaseA<derResponse2>))]
public abstract class BaseA
{
    [DataMember(Order = 1)]
    public int baseA = 10;
}
[Serializable]
[DataContract]
[ProtoInclude(2, typeof(der1))]
[ProtoInclude(3, typeof(der2))]
public abstract class BaseA<T> : BaseA where T : ResponseBaseA, new()
{
    T _Response;
    /// <summary>
    /// 
    /// </summary>
    [System.Runtime.Serialization.DataMember(Order = 1)]
    public new T Response
    {
        get { return _Response; }
        set { _Response = value; }
    }
}
[Serializable]
[DataContract]
public class der1 : BaseA<derResponse1>
{
    [DataMember(Order = 1)]
    public int derive1 = 20;
}
[Serializable]
[DataContract]
public class der2 : BaseA<derResponse2>
{
    [DataMember(Order = 1)]
    public int derive2 = 30;
}
[Serializable]
[DataContract]
[ProtoInclude(2, typeof(derResponse1))]
[ProtoInclude(3, typeof(derResponse2))]
public abstract class ResponseBaseA
{
    [DataMember(Order = 1)]
    public int responseBaseA = 100;
}
[Serializable]
[DataContract]
public class derResponse1 : ResponseBaseA
{
    [DataMember(Order = 1)]
    public int derResp1 = 200;
}
[Serializable]
[DataContract]
public class derResponse2 : ResponseBaseA
{
    [DataMember(Order = 1)]
    public int derResp2 = 300;
}

}

我们创建它们的方式在这里

RequestSection section = new RequestSection();
der1 der1 = new der1();
der2 der2 = new der2();
section.Allrequests.Add(der1);
section.Allrequests.Add(der2);

我无法使用protobuf-net(v1和v2都是未知的子类型)序列化部分,所以我正在尝试运行时模型。

这是iam使用的原型文件。

message RequestSection{
    repeated BaseA requests=1;
}
message BaseA{
    optional int32 baseA=1;
    optional BaseA1Generic BaseA1Generic =2;
    optional BaseA2Generic BaseA2Generic =3;
}
message BaseA1Generic{
    optional ResponseBaseA baseResponse =1; 
    optional Der1 requestDer1 = 2;
}
message BaseA2Generic{
    optional ResponseBaseA baseResponse =1; 
    optional Der2 requestDer2 = 3;
}
message ResponseBaseA{
    optional int32 responseBaseA = 1;
    optional derResponse1 derivedResponse1 =2;   
    optional derResponse2 derivedResponse2 =3;   
}
message derResponse1{
    optional int32 derResponse1 = 1;
}
message derResponse2{
    optional int32 derResponse2 = 1;
}
message Der1{
    optional int32 d1=1;
}
message Der2{
    optional int32 d2=1;
} 

它没有在Java端进行反序列化,只得到这个

requests {
  baseA: 10
  1000: "302>02b24"
}
requests {
  baseA: 10
  1001: "302>02b36"
}

我试图使我的proto文件通用,因为我可能在部分请求下有任何类(未来可能有der1/der2/或更多)。

目前的问题是,您的模型为BaseA<derResponse1>BaseA<derResponse2>指定了der1der2,这意味着有两条通往der1/der2的路径。在v2中,我们可以通过显式指定每个封闭泛型类型的继承来避免这种情况;所以:从BaseA<T>中删除两个[ProtoInclude(...)],然后使用:

RuntimeTypeModel.Default[typeof(BaseA<derResponse1>)].AddSubType(2,typeof(der1));
RuntimeTypeModel.Default[typeof(BaseA<derResponse2>)].AddSubType(3,typeof(der2));

作为旁注;这里不要求它们使用不同的数字,因为它们是独立的。如果你喜欢,他们都可以使用字段2;但是使用不同的字段号也是可以的。

最新更新