Java的伪泛型简单的证明

本文探讨了Java中泛型方法的重载问题,并通过一个具体的例子解释了为何两个泛型方法无法实现重载。文章揭示了Java泛型背后的实现机制——类型擦除,并说明了这如何影响方法的签名。

这段代码的test1方法会不会重载成功?

public class Test  {

    public  void test1(List<String> lists){
        System.out.println("list1");

    }
    public  void test1(List<Integer> list2){
        System.out.println("list2");
    }
    public static void main(String[] args){

        System.out.println("haha");

    }
}

这段代码,编译工具就会提醒错误:

大概意思test1方法和test1方法的参数类型相同。

运行起来,编译就会发生错误。

原因是,

java采用语法糖的形式实现了java的泛型,在编译时会擦除语法糖,恢复基本语法的实现。上面的test1中的参数均会被擦除成原生类型List<E>,所以参数相同,不能实现方法重载。

以下是从参考引用中提取的 Java 基础内容: ### 字符串常量池与 `new String` JVM 用字面量”abc“去字符串常量池中尝试获取“abc”对应的 String 对象的引用。若获取成功,则让 `new String` 对象引用常量池中的"abc”;若获取失败,则在堆内存中创建一个"abc"的 String 对象(第二个对象),并把它的引用保存在字符串常量池,然后让 `new String` 对象引用常量池中的"abc" [^1]。 ### 异常处理 - `ClassCastException` 当程序尝试将一个对象强制转换为不是其实例的类时,会抛出 `ClassCastException`。例如 `Object obj = new Integer(100); String str = (String) obj;` 就会抛出该异常 [^2]。 ### Java - 类擦除 Java伪泛型,在编译期间,所有的信息都会被擦掉。Java基本上是在编译器这个层次上实现的,生成的字节码中不包含中的类信息。使用时加上的类参数,在编译器编译时会去掉,这个过程称为类擦除。以下代码可以证明擦除: ```java public class Test { public static void main(String[] args) { ArrayList<String> list1 = new ArrayList<String>(); list1.add("abc"); ArrayList<Integer> list2 = new ArrayList<Integer>(); list2.add(123); System.out.println(list1.getClass() == list2.getClass()); // 返回结果是 true,说明 String 和 Integer 都被擦除掉了,只剩下原始类。 // 原始类就是擦除信息后,最后在字节码中的类变量的真正类; } } ``` [^3] ### 数组查找注意事项 在数组中查找数字第一次出现的位置时,不能在找到目标后就往前遍历,否则对于一些特殊数据,如 `1 2 2 2 2 2 2 2 2 2 2`,查找数字 2 第一次出现的下标时,时间复杂度会达到 O(n*m) [^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值