Self-referencing template parameters
Oskar Linde
oskar.lindeREM at OVEgmail.com
Mon Mar 20 03:43:07 PST 2006
Erik Rasmussen skrev:
> One way that I have found java's generics to be useful is in doing
> something like this:
>
> ---
> public abstract class Animal<T extends Animal<T>>
> {
> public abstract T[] procreate(T mate);
> }
>
> public class Monkey extends Animal<Monkey>
> {
> public Monkey[] procreate(Monkey mate)
> {
> // make sweet monkey love
> }
> }
> ---
>
> Although you're not strictly forced to by the compiler, if you make it a
> policy to always make your template variable the same as your concrete
> subclass, then you have forced any class that extends Animal to provide
> a way to "procreate" with its own kind.
>
> I seem to be unable to implement this pattern in D. The following
> doesn't work:
>
> ---
> abstract class Animal(T : Animal!(T))
> {
> abstract T[] procreate(T mate);
> }
> ---
>
> It doesn't like that template definition on the first line. It says,
> "template instance does not match any template declaration".
>
> Any ideas?
The problem is that this line contains a recursive instantiation:
abstract class Animal(T : Animal!(T))
Animal!(T) has to be instantiated before the compiler knows how to what
type it is.
But if you place a static assert in a place outside what the compiler
needs to deduce the type:
class Animal(T) {
this() {
static assert(is(T : Animal));
}
public abstract T[] procreate(T mate);
}
Things work as they should.
/Oskar
More information about the Digitalmars-d-learn
mailing list