zoukankan      html  css  js  c++  java
  • 泛型---(静态方法中为什么不能引用类级别的参数)

    我觉得最主要的原因是因为泛型擦除。
    class Demo<T> {
    public void add(T t) {

    //...
    }

    }
    编译后通过反编译:
    D: est>javap -s -p Demo
    Compiled from "Demo.java"
    public class Demo extends java.lang.Object{
    public Demo();
    Signature: ()V
    public void add(java.lang.Object);
    Signature: (Ljava/lang/Object;)V
    }
    所以,非静态方法正是由于需要先有对象,进而在使用泛型的时候可以确定安全检查的限制条件。
    Demo<String> d = new Demo<String>() ;
    d.add("str") ; //这里你就只能添加String类型的。

    而静态方法不需要构件对象,所以他在调用方法是,根本没有判断参数的约束条件,所以虚拟机压根就不希望这种事情发生,所以在编译时就报错了。

    public class Test<T> {
        public static <T> void  test(T t){
            //......
        }
        
        public static void  test(T t){//Cannot make a static reference to the non-static type T
            //......
        }
    }

    <T>让static方法拥有泛型的能力。

    泛型还可以用于内部类与匿名内部类

    擦除的神秘之处:

      在泛型代码内部,无法发获得任何有关泛型参数类型的信息。(泛型的实现基于擦除机制)

    泛型中的边界:example:<? extends 类型>

  • 相关阅读:
    Sass
    Less文件的建立
    面试问题整理
    高光谱图像分类部分名词解析
    监督学习,无监督学习和半监督学习
    git
    node.js安装及其环境配置
    浏览器从输入网址到渲染出页面的过程
    node的api
    模块与包管理工具
  • 原文地址:https://www.cnblogs.com/jswang/p/7997763.html
Copyright © 2011-2022 走看看