我在使用Protobuf.net的项目中遇到此异常:InvalidOperationException"Unexpectedsub-type:foo"我要发送一个类,如下所示:classmessage{listlistOfBars;}foo继承offbar,但是protobuf似乎对此感到窒息并生成上面的异常。有什么办法解决这个问题吗?我需要能够在列表中包含bar的所有不同子类型,因此更受类型约束的解决方案将很困难/不可能。 最佳答案 我可能弄错了,但我认为你需要在继承类上指定哪些子类型从它继承,例如:[Serializable,P
是否可以在基类中标记一个在子类中仍然有效的属性?问题可能非常针对序列化,但我绝对认为也可以有其他用途。考虑以下代码:usingSystem;usingSystem.IO;usingSystem.Xml.Serialization;namespaceCode.Without.IDE{[Serializable]publicabstractclassC1{[XmlIgnore]publicabstractboolIsValid_C1{get;set;}}[Serializable]publicclassC2:C1{publicboolIsValid_C2{get;set;}publicov
我想序列化一个非常普通的类,但要注意的是它嵌套在一个静态类中,如下所示:publicstaticclassStaticClass{[Serializable]publicclassSomeType{...}}这段代码:StaticClass.SomeTypeobj=newStaticClass.SomeType();XmlSerializermySerializer=newXmlSerializer(typeof(obj));产生这个错误:StaticClass.SomeTypecannotbeserialized.Statictypescannotbeusedasparameters
如何强制子类实现其父类(superclass)的某些属性?原因是我想使用属性来获取有关该类的一般信息,例如“显示名称”、“说明”或“功能”。所以我想我可以在父类(superclass)中实现它们并强制子类实现这些属性。是否有类似于方法的抽象属性?[abstractDeclareMe]publicabstractclassInheritMe{publicabstractvoidDeclareMe();} 最佳答案 由于你的类迟早要运行,你可以在你的基类中添加检查机制来验证你的子类中某些属性的存在。这里有一些示例代码。classProg
我有一个类Animal,及其子类Dog.我有一个List我想添加一些List的内容到List.有没有比只投List更好的方法呢?到List,然后使用AddRange? 最佳答案 如果您使用的是C#4,则不需要转换:Listanimals=newList();Listdogs=newList();animals.AddRange(dogs);这是允许的,因为AddRange()接受IEnumerable,即covariant.如果您没有C#4,那么您将不得不迭代List并转换每个项目,因为协方差只是在那时添加。您可以通过.Cast完成
我有以下结构:abstractclassBase{publicabstractListGet();//Whatshouldbethegenerictype?}classSubOne:Base{publicoverrideListGet(){}}classSubTwo:Base{publicoverrideListGet(){}}我想创建一个抽象方法,返回具体子类的任何类。因此,正如您从示例中看到的那样,SubOne中的方法应该返回List而SubTwo中的方法应该返回List.我在基类中声明的签名中指定什么类型?[更新]感谢您发布的答案。解决方案是使抽象类通用,如下所示:abstrac
我可以像在Java中一样在C#/.net中创建抽象类的实例吗?附加信息我想我们很多人不明白我的意思?所以,在java中,我可以像这样创建抽象类:简单的抽象类:/***@authorjitm*@version0.1*/publicabstractclassTestAbstract{publicabstractvoidtoDoSmth();}创建抽象类实例的代码/***@authorjitm*@version0.1*/publicclassMain{publicstaticvoidmain(String[]args){TestAbstracttestAbstract=newTestAbst
我有以下两个类(模型),一个是基类,另一个是子类:publicclassBaseClass{publicstringBaseProperty{get;set;}}publicclassChildClass:BaseClass{publicstringChildProperty{get;set;}}在应用程序中,我使用泛型动态调用ChildClassListpropertyNames=newList();foreach(PropertyInfoinfointypeof(T).GetProperties()){propertyNames.Add(info.Name);}在这里,在prope
我今天之前从未遇到过这个问题,想知道实现这种行为的约定/最佳实践是什么。基本设置是这样的:publicinterfaceIDispatch{voidDispatch();}publicclassFoo:IDispatch{voidIDispatch.Dispatch(){DoSomething();}}publicclassBar:Foo{...}Bar需要子类化Foo,因为它与Bar共享所有相同的属性,并且引入了2个我需要遇到的新属性。我遇到的问题是Foo还需要一个稍微不同的Dispatch()实现。通常它会被重写,但这对接口(interface)方法无效,所以让Bar也实现IDis
情况我有一个类在内部处理许多不同类型的文件路径:一些是本地的,一些是远程的;一些相对的,一些绝对的。过去的情况是,它的许多方法将它们作为string相互传递,但要准确跟踪每个方法期望的路径类型变得非常困难。所需的修复所以我们基本上想typedef四种不同的类型到string:RemoteRelative,LocalRelative,RemoteAbsolute和LocalAbsolute。这样,静态类型检查器可以帮助开发人员确保他们提供和期望具有正确语义的string。不幸的是,string在BCL中是密封的,所以我们不能通过简单的继承来做到这一点。并且没有简单的typedef,所以我