class Sample<T> : IDisposable // case A
{
public void Dispose()
{
throw new NotImplementedException();
}
}
class SampleB<T> where T : IDisposable // case B
{
}
class SampleC<T> : IDisposable, T : IDisposable // case C
{
public void Dispose()
{
throw new NotImplementedException();
}
}
Le cas C est la combinaison du cas A et du cas B. Est-ce possible? Comment rendre le cas C correct?
D'abord les interfaces implémentées, puis les contraintes de type génériques séparées par where
:
class SampleC<T> : IDisposable where T : IDisposable // case C
{ // ↑
public void Dispose()
{
throw new NotImplementedException();
}
}
Vous pouvez le faire comme ceci:
public class CommonModel<T> : BaseModel<T>, iMessage where T : ModelClass
class SampleC<T> : IDisposable where T : IDisposable // case C
{
public void Dispose()
{
throw new NotImplementedException();
}
}
class SampleC<T> : IDisposable where T : IDisposable
{
...
}