C#省略嵌套类型参数

时间:2018-08-30 12:07:24

标签: c# list constructor type-parameter

我想创建一个 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类?

2 个答案:

答案 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);
}