public abstract class EntityBase { ... }
public interface IFoobar
{
void Foo<T>(int x)
where T : EntityBase, new();
}
public interface IFoobar<T>
where T : EntityBase, new()
{
void Foo(int x);
}
public class Foobar<T> : IFoobar, IFoobar<T>
where T : EntityBase, new()
{
public void Foo(int x) { ... }
void IFoobar.Foo<T>(int x) { Foo(x); }
}
Я получаю предупреждение о компиляторе: Type parameter 'T' has the same name as the type parameter from outer type '...'
Я пробовал делать: void IFoobar.Foo<U>(int x) { Foo(x); }
, но тогда я не могу гарантировать, что U и T одинаковы. То, как реализуется класс Foobar, очень важно, чтобы они были одинаковыми.
Я также попытался сделать: void IFoobar.Foo<U>(int x) where U : T { Foo(x); }
, однако это не гарантирует, что U и T равны, и это не позволяет мне переопределить ограничение, поскольку оно было определено на интерфейсе.