有没有一种方法可以对抽象方法进行模板化,以便抽象方法的参数与实现子类的类型相同?

Is there a way to template astract methods so that a parameter to an abstract method will be typed the same as the implementing subclass?

有没有办法对抽象方法进行模板化,以便抽象方法的参数类型与实现子类的类型相同?换句话说,如果我们有:

class Super {
    abstract void a_method( <Sub> param );
}

class Sub_A extends Super {
    void a_method( Sub_A param ){
        ...
    }

class Sub_B extends Super {
    void a_method( Sub_B param ){
        ...
    }
}

然后每个子类将自己的类型作为此方法的参数。我想避免使用接口或反射。

通常的做法是引入一个通用参数:

abstract class Super<Sub extends Super> {
    abstract void a_method(Sub param);
}

class Sub_A extends Super<Sub_A> {
    void a_method(Sub_A param) {

    }
}

class Sub_B extends Super<Sub_B> {
    void a_method(Sub_B param) {

    }
}

据我所知,您不能强制子类将自己传递为 T,例如可以定义 class Sub_C extends Super<Sub_A>。不确定这是否是个问题。


遵循 java 命名约定,它应该如下所示:

abstract class Super<S extends Super> {
    abstract void aMethod(S param);
}

class SubA extends Super<SubA> {
    void aMethod(SubA param) {

    }
}

class SubB extends Super<SubB> {
    void aMethod(SubB param) {

    }
}

。以防万一有人遇到这个但像我一样使用 Kotlin,这里是它的要点

abstract class AbstractParam

abstract class AbstractClass<T: AbstractParam> {
    abstract fun f(p: T)
}

class Param: AbstractParam()

class Class: AbstractClass<Param>() {
    override fun f(p: Param) {}
}