如果可能的话,我想做这样的事情。
internal sealed class BufferPool<T, K> : K<Buffer<T>>
{
public BufferPool() : base() {}
//etc...
}然后像这样调用这个类:
BufferPool<byte, HashSet> buffers;
buffers = new BufferPool<byte, HashSet>(bufferCapacity);或
BufferPool<byte, List> buffers;
buffers = new BufferPool<byte, List>(bufferCapacity);发布于 2012-01-18 02:21:18
不能从类型参数继承(请参见How to inherit from a generic parameter?)。您可以做的是将类型参数约束为有用的类型和普通构造函数,并在类中实例化一个实例:
internal sealed class BufferPool<T, K> : IEnumerable<T> where K : IEnumerable<T>, new()
{
K _bufferImpl = new K();
public BufferPool() : base() { }
//etc...
}发布于 2012-01-18 02:26:32
这是行不通的,因为编译器需要知道您的类正在继承/实现什么类型/接口,以确定您的类是否满足该类型的约定要求。这包括重写抽象成员、实现接口成员等。
当你在那里只有一个类型参数时,协定是未知的。这是编译器不支持的情况。
https://stackoverflow.com/questions/8899479
复制相似问题