发现的一些有关泛型的面试题

本文深入解析Java泛型概念,包括其工作原理、限定与非限定通配符的区别、List泛型参数的理解,以及如何编写泛型方法和实现LRU缓存。同时探讨了泛型在Array中的应用限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


泛型是什么 ? 使用泛型的好处(初级和中级)

泛型就是一种不确定的数据类型。比如比如:ArrayList< E> E就是泛型。 这种不确定的数据类型需要在使用这个类的时候才能够确定出来。默认泛型是Object类型。它提供了编译期的类型安全,确保你只能把正确类型的对象放入集合中,避免了在运行时出现ClassCastException。

泛型是如何工作的

泛型是通过类型擦除来实现的,编译器在编译时擦除了所有类型相关的信息,所以导致了数据类型的不确定。

泛型中的限定通配符和非限定通配符

***限定***通配符对类型进行了限制。有两种限定通配符,一种是<? extends T>它通过确保类型必须是T的子类来设定类型的上界,另一种是<? super T>它通过确保类型必须是T的父类来设定类型的下界。泛型类型必须用限定内的类型来进行初始化,否则会导致编译错误。另一方面<?>表示了非限定通配符,因为<?>可以用任意类型来替代。

List<? extends T>和List <? super T>之间有什么区别 ?

它涉及到限定通配符, List<? extends T>可以接受任何继承自T的类型的List,而List<? super T>可以接受任何T的父类构成的List。例如List<? extends Number>可以接受List< Integer >或List< Float >。

如何编写一个泛型方法,让它能接受泛型参数并返回泛型类型?

public V put(K key, V value) {
 return cache.put(key, value);
}

编写一段泛型程序来实现LRU缓存?

public LRUCache<k,v> extends LinkedHashMap<k,v>{
		private int cacheSize; 
   public LRUCache(int cacheSize) {
        super(16, 0.75, true);
        this.cacheSize = cacheSize;
        }
   protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
        return size() >= cacheSize;
  }

}

你可以把List< String >传递给一个接受List< Object>参数的方法吗?

List< Object >可以存储任何类型的对象包括String, Integer等等,而List< String >却只能用来存储Strings。

Array中可以用泛型吗

不能,Array事实上并不支持泛型,可以使用List来代替Array,因为List可以提供编译期的类型安全保证,而Array却不能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值