Task or Task
This is in line with what they did for the foreach
keyword (see section 8.8.4 of the C# language specification "The foreach statement").
Basically, it's duck-typing; if the type implements a MoveNext
method and a Current
property, that's all that's needed for the C# compiler to know how to iterate through a sequence exposed by an object.
This also applies with collection initializers (see section 7.6.10.3 of the C# language specification "Collection Initializers"); the only requirement is that the type implements the System.Collections.IEnumerable interface and have an Add
method.
That said, the await keyword just sticks to prior precedent, not requiring specific interface implementations (although the interfaces supply those methods if you choose to use them), just a pattern of methods that the compiler can recognize.