java泛型之四——上下限

本文详细解析了Java泛型的上限与下限设定方法,包括类与接口的上下限规定,以及如何在实际代码中应用这些规则。通过具体实例展示了泛型限制的使用场景。

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

 指定上限为T类:表示泛型必须为T类及其子类;
 指定上限为T接口:表示泛型必须为T接口及其实现类;
 不管是类还是接口,格式都为extends T;
 指定下限为T类:表示泛型必须为T类及其父类;
 指定上限为T接口:表示泛型必须为T接口及其父接口;
 不管是类还是接口,格式都为? super T;
 不能只设置下限,设置下限的同时必须设置上限(参数例外);


interface Inf1<T> {
	
}
interface Inf2 {
	
}
class A<T> {
	
}
class  B<T> extends A<T> implements Inf1{
	
}
 
class C<T> extends B<T> {
	
}
 
class D extends C {
	
}


一、类的上限
 例:

泛型T上限为B

class Dog<T extends B> {
	private T t;
	private void fun1() {
		/**T的类型为B*/
		Dog dog = new Dog();
	}
	private void fun2() {
		/**T的类型为B*/
		Dog<B> dog = new Dog<B>();
	}
	private void fun3() {
		/**T的上限为B,即T只能是T及其子类所以下面代码是错的*/
		Dog<A> dog = new Dog<A>();
	}
}

二、类的上下限
例:

T的上限为A,下限为C

class Cat<T extends A<? super C>> {
	private T t;
	private void fun1() {
		 Cat<A<? super C>> cat1 = new Cat<A<? super C>>();
		 cat1.t = new A();
		 cat1.t = new B();
		 cat1.t = new C();
	}
}

三、方法上限下,与类的上下限设置一样

例:

class Point<T,K,V> {
	
}
class Test {
	/**强制要求show1参数Point对象被创建时,指定泛型
	 * T上限为A;
	 * K上限为Inf1;
	 * V下限为B;
	 * */
	public void show1(Point<? extends A, ? extends Inf1, ? super B> p) { 
	}
	/**
	 * T为B符合T上限为A; 因为B继承A类
	 * K为B符合K上限为Inf1;因为B实现了Inf1
	 * V为A符合V下限为B; 因为 A是B的父类
	 */
	private void fun() {
		Point<B, B, A> point = new Point<B,B,A>();
		this.show1(point);
	}
}



### Java 概述 Java是一种允许程序员编写可以处理多种数据类的通用类、接口和方法的技术。通过引入,程序可以在编译期捕获类错误,从而减少运行时异常的发生并提高代码的安全性和可读性[^3]。 #### 的基本概念 的核心思想是使类或方法能够操作任何指定的数据类,而无需在定义阶段固定具体类。这使得开发者能够在不牺牲类安全的情况下重用相同的逻辑结构。例如,在集合框架中广使用的`List<T>`就是一个典的例子,其中`T`表示任意类参数。 #### 定义带的类 下面是一个简单的带有单个类参数 `T` 的类的例子: ```java public class Box<T> { private T content; public void setContent(T content) { this.content = content; } public T getContent() { return content; } } ``` 在这个例子中,`Box` 类被设计成能存储任何类的对象。当实例化这个类的时候,你可以指明具体的类,比如 `Integer`, `String` 或者其他自定义的对象类[^4]。 #### 使用通配符增强灵活性 有时我们希望某些变量或者方法接受更广的类范围而不是特定的一个子集。这时就可以利用通配符(`?`)来实现这一点。有两种主要形式:“上限限定” 和 “下限限定”。 - **上限限定** (`<? extends UpperBoundType>`): 表示该位置上的实际类必须是指定上界类或者是其派生类之一。 - **下限限定** (`<? super LowerBoundType>`): 则相反,它意味着此处的实际类应该是给定低边界类本身或是它的某个超类。 这里有一个展示如何运用这些特性的片段: ```java static void copy(List<? extends Number> src, List<? super Integer> dest){ for(Number element : src){ dest.add((Integer)element); } } ``` 上述函数展示了从一个列表复制到另一个列表的过程,源列表中的元素需为Number及其子类;目标列表则应容纳至少Integer类的项[^5]。 #### 解决常见问题 假设存在这样一个需求场景——创建一个工具类用于比较两个容器内的所有项目是否相匹配。如果不采用,则每次都需要针对不同种类的数据重新编码相应的版本。然而借助于机制之后,只需撰写一次即可适用于各种情况下的对比作业。 ```java public static <E> boolean compare(Collection<E> c1, Collection<E> c2){ if(c1.size()!=c2.size())return false; Iterator<E> i1=c1.iterator(); Iterator<E> i2=c2.iterator(); while(i1.hasNext()){ E o1=i1.next(),o2=i2.next(); if(!Objects.equals(o1,o2))return false; } return true; } ``` 此段代码实现了对于任意两组Collection成员之间的一致性检验功能[^6]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值