Java中的下界通配符wrt泛型方法是什么?

泛型是Java中的一个概念,您可以在其中启用类,接口和方法,以接受所有(引用)类型作为参数。换句话说,该概念使用户能够动态选择方法(类的构造函数)接受的引用类型。通过将类定义为泛型,可以使其成为类型安全的,即它可以作用于任何数据类型。

要定义泛型类,您需要在类名称后的尖括号“ <>”中指定要使用的类型参数,并将其视为实例变量的数据类型,然后继续执行代码。

示例

class Student<T>{
   T age;
   Student(T age){
      this.age = age;
   }
   public void display() {
      System.out.println("Value: "+this.age);
   }
}
public class GenericsExample {
   public static void main(String args[]) {
      Student<Float> std1 = new Student<Float>(25.5f);
      std1.display();
      Student<String> std2 = new Student<String>("25");
      std2.display();
      Student<Integer> std3 = new Student<Integer>(25);
      std3.display();
   }
}

输出结果

Value: 25.5
Value: 25
Value: 25

通配符

除了泛型(T)中的类型化参数外,您还可以使用“?”来表示未知类型。您可以将通配符用作-

  • 参数类型。

  • 领域。

  • 本地字段。

对通配符的唯一限制是,您不能在调用它时将其作为泛型方法的类型参数。

Java提供3种类型的通配符,即上限,下限,无限制。

下界通配符

上限通配符允许使用特定类的所有子类型作为类型化参数。

同样,如果我们使用下界通配符,则可以限制“?”的类型 到特定类型或超类型。

例如,如果要接受Collection对象作为方法的参数,而类型化的参数作为Integer类的超类,则只需要声明一个带有Integer类的下限通配符。

要创建/声明下界通配符,只需在“?”之后指定super关键字即可。然后是类名。

示例

以下Java示例演示了下界通配符的创建。

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Iterator;
public class LowerBoundExample {
   public static void sampleMethod(Collection<? super Integer> col){
      Iterator it = col.iterator();
      while (it.hasNext()) {
         System.out.print(it.next()+" ");
      }
      System.out.println("");
   }
   public static void main(String args[]) {
      ArrayList<Integer> col1 = new ArrayList<Integer>();
      col1.add(24);
      col1.add(56);
      col1.add(89);
      col1.add(75);
      col1.add(36);
      sampleMethod(col1);
      List<Object> col2 = Arrays.asList(22.1f, 3.32f, 51.4f, 82.7f, 95.4f, 625.f);
      sampleMethod(col2);
   }
}

输出结果

24 56 89 75 36
22.1 3.32 51.4 82.7 95.4 625.0

如果将除Integer以外的其他类型的收集对象及其超类型作为参数传递给上述程序的sampleMethod(),则会生成编译时错误。

示例

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Iterator;
import java.util.HashSet;
public class LowerBoundExample {
   public static void sampleMethod(Collection<? super Integer> col){
      Iterator it = col.iterator();
      while (it.hasNext()) {
         System.out.print(it.next()+" ");
      }
      System.out.println("");
   }
   public static void main(String args[]) {
      ArrayList<Integer> col1 = new ArrayList<Integer>();
      col1.add(24);
      col1.add(56);
      col1.add(89);
      col1.add(75);
      col1.add(36);
      sampleMethod(col1);
      List<Object> col2 = Arrays.asList(22.1f, 3.32f, 51.4f, 82.7f, 95.4f, 625.f);
      sampleMethod(col2);
      HashSet<Double> col3 = new HashSet<Double>();
      col3.add(25.225d);
      col3.add(554.32d);
      col3.add(2254.22d);
      col3.add(445.21d);
      sampleMethod(col3);
   }
}

编译时错误

LowerBoundExample.java:34: error: incompatible types: HashSet<Double> cannot be converted to Collection<? super Integer>
      sampleMethod(col3);
                  ^
Note: Some messages have been simplified; recompile with -Xdiags:verbose to get full output
1 error