类型参数边界 - 未经检查的覆盖:return 类型需要未经检查的转换

Type parameter bounds - Unchecked overriding: return type requires unchecked conversion

如何消除以下代码中的警告 Unchecked overriding: return type requires unchecked conversion. Found 'org.example.AAndB<java.lang.integer>', required 'T'.

我尝试设计一个接口 (Interface),使其不会明确声明 return 类型的方法 get() (AAndB<Integer>) 但是而是枚举结果必须实现的接口 (<T extends B<Integer> & A> T).

package org.example;

class InterfaceImpl implements Interface {

    public AAndB<Integer> get() {
        //  ^----- Unchecked overriding: return type requires unchecked conversion. Found 'org.example.AAndB<java.lang.integer>', required 'T'.
        final AAndB<Integer> aAndB = new AAndB<Integer>();
        return aAndB;
    }
}

interface Interface {
    <T extends  B<Integer> & A> T get();
}

class AAndB<T> implements A, B<T> {

    public void a() {

    }

    public void b(T t) {

    }
}

interface A {
    void a();
}

interface B<T> {
    void b(T t);
}

我们可以清楚地看到,您实现的方法签名与 Interface 中方法定义的签名不匹配:

public AAndB<Integer> get()

不一样
public <T extends B<Integer> & A> T get()

T 的定义是方法签名的一部分。要遵守 Interface.get,您需要编写:

class InterfaceImpl implements Interface {
    public <T extends B<Integer> & A> T get() {
        // ...
    }
}

接口方法签名中的有界泛型并不意味着您可以替换您自己的方法实现中范围内的任何类型。

如果希望能够指定不同的return类型,需要参数化Interface:

class InterfaceImpl implements Interface<AAndB<Integer>> {

    public AAndB<Integer> get() {
        final AAndB<Integer> aAndB = new AAndB<Integer>();
        return aAndB;
    }
}

interface Interface<T extends B<Integer> & A> {
     T get();
}

你完全误解了<T extends B<Integer> & A> T get();的意思。

<T extends B<Integer> & A> T get(); 声明了一个 泛型方法 。这意味着该方法必须能够与任何 T 一起正常工作——它必须与 T 一起正常工作,因为任何调用者可能希望 T 成为任何人,甚至不知道 T 是。

这并不意味着该方法可以选择 T 成为它想要的。恰恰相反。该方法别无选择,必须与为其选择的任何 T 一起使用。