我想创建一个 Operation 类,该类具有将 Data 作为输入并提供 Data 作为输出的功能:
public abstract class Data { }
public abstract class Operation {
public abstract Data Run (Data input);
}
我希望与数据输入不同的数据输出具有灵活性:
public abstract class Data { }
public abstract class Operation<T1, T2>
where T1: Data
where T2: Data
{
public abstract T2 Run (T1 input);
}
最后,我想强制所有数据实施某种类型的列表:
public abstract class Data<T> : List<T> { }
public abstract class Operation<T1, T2>
where T1: Data // Error
where T2: Data // Error
{
public abstract T2 Run (T1 input);
}
然后我得到错误:“使用通用类型'Data'需要1个类型参数” 。
在没有在where子句中显式设置数据类型的情况下,如何解决此错误?
理想情况下,需要执行以下代码:
public class Operation <????> { ???? }
public class Data<T> : List<T> {}
public class Foo {}
public class FooData : Data<Foo> {}
public class Bar {}
public class BarData : Data<Bar> {}
public class FBOperation : Operation<FooData, BarData> {
public override BarData Run (FooData input) {
return ...;
}
}
我应该如何实现Operation类?
答案 0 :(得分:1)
您可以执行以下操作:
public class Foo { }
public class Bar { }
public interface IData { }
public interface IData<T> : IData
{
List<T> List{ get; set; }
}
public class Foos : IData<Foo>
{
public List<Foo> List{ get; set; }
}
public class Bars : IData<Bar>
{
public List<Bar> List{ get; set; }
}
public abstract class Operation<TD1, TD2>
where TD1 : IData
where TD2 : IData
{
public abstract TD2 Run(TD1 input);
}
public class FbOperation : Operation<Foos, Bars>
{
public override Bars Run(Foos input)
{
// TODO
return new Bars();
}
}
答案 1 :(得分:0)
问题在于您不再具有Data
类型,您已经向其添加了通用参数T
并获得了完全不同的类型Data<T>
,因此约束where T1: Data
不正确。
最直接的解决方案是将此附加参数传播为Operation
类型。
public abstract class Operation<T1, T2, TItem>
where T1: Data<TItem>
where T2: Data<TItem>
{
public abstract T2 Run (T1 input);
}
但是,对我来说,事情有点太复杂了。考虑一下在您的Operation<,>
类上添加这些非常严格的限制有什么好处。
这个基本版本可能足以描述一系列操作类型。
public abstract class Operation<T1, T2>
{
public abstract T2 Run (T1 input);
}