泛型T和?的区别

2019-07-11  本文已影响0人  Apple_Boy

泛型的使用有效的降低了代码的冗余,减少了重复无用的代码,使代码的可读性更高,更简洁,同时也缩短了搬 砖工人的重复劳动时间。

种类:
  T:表示确定的类型,最常用的泛型表示方法。
  ? :表示不确定的类型,类似于通配符。
  K:一般用于键值对中的 –>键
  v:一般用于键值对中的 –>值
  E:表示枚举。

范围:
  T:表示同一种类型。
  ?:表示任意类型。
写法:
  T:<T>
  ?:<?>、<? extends Object>、<? super Object>
注意点1:
  <? extends XX>:表示XX类型,和XX的子类型。
  <? super XX>:表示XX类型,和XX的父类型
比如:如果只指定了<?>,而没有extends,则默认是允许Object及其下的任何Java类了。也就是任意类。
注意点2:
  class<T>:实例化的时候,需要指定具体类型。
  class<?>:可以表示所有类型。

泛型的好处如:
开始版本:

public void write(Integer i, Integer[] ia);
public void write(Double  d, Double[] da);

泛型版本:

public <T> void write(T t, T[] ta);

“<T>"和"<?>",首先要区分开两种不同的场景:
 第一,声明一个泛型类或泛型方法。
 第二,使用泛型类或泛型方法。
 类型参数“<T>”主要用于第一种,声明泛型类或泛型方法。
 无界通配符“<?>”主要用于第二种,使用泛型类或泛型方法

泛型类派生出的子类
分两种情况:
  子类明确泛型类的类型参数变量
  子类不明确泛型类的类型参数变量

//把泛型定义在接口上
public interface Inter<T> {
    public abstract void show(T t);
}

/**
 * 子类明确泛型类的类型参数变量:
 */
public class InterImpl implements Inter<String> {
    @Override
    public void show(String s) {
        System.out.println(s);
    }
}
/**
 * 子类不明确泛型类的类型参数变量:
 *      实现类也要定义出<T>类型的
 */
public class InterImpl<T> implements Inter<T> {
    @Override
    public void show(T t) {
        System.out.println(t);
    }
}
public static void main(String[] args) {
        //测试第一种情况
        //Inter<String> i = new InterImpl();
        //i.show("hello");

        //第二种情况测试
        Inter<String> ii = new InterImpl<>();
        ii.show("100");

    }

值得注意的是:

上一篇下一篇

猜你喜欢

热点阅读