这篇文章主要介绍了java编程泛型限定的相关内容,具有一定参考价值,需要的朋友可以了解下。
泛型 一般 出现在集合中,迭代器中 也会出现!
泛型 是为了 提高代码的 安全性。 泛型 确保数据类型的唯一性。
在我们常用的容器中, 越是单一越好处理啊!
泛型的限定:
立即学习“Java免费学习笔记(深入)”;
? 是通配符 指代 任意类型
泛型的限定上限:
主要模块:首页商品推荐 /顾客留言发布 /商品分类浏览 /按商品分类、关键字搜索商品 /商品购物车 人信息中心 /显示商品详细介绍以及多图片显示功能 /商品类别管理有分大类中类的类别设定商品搜索类别设定 /商品管理有临时关闭不在线功能 /订单管理 /支付类型管理模块 留言管理 /后台权限分级管理 /密码修改 /新闻管理 /网站配置管理 /滚动广告管理v1.58更新:1、增强支付接口设置。2、内置支
接受 E 或者 E 的子类型。
泛型的限定下限:
super E> 接收 E 或者 E 的父类。
泛型的限定上限 (定义父类 填装子类 类型!)
下面我们看看具体代码示例
package newFeatures8;
import java.util.*;
/*
? 通配符。也可以理解为占位符。
泛型的限定;
? extends E: 可以接收E类型或者E的子类型。上限。
? super E: 可以接收E类型或者E的父类型。下限
*/
class GenericDemo6 {
public static void main(String[] args) {
/*
* ArrayList al = new ArrayList();
*
* al.add("abc1"); al.add("abc2"); al.add("abc3");
*
* ArrayList al1 = new ArrayList(); al1.add(4);
* al1.add(7); al1.add(1);
*
* printColl(al); printColl(al1);
*/
//ArrayList al = new ArrayList();error
//为了解决等号两边泛型不一致的情况,jdk1.7以后可以这么写
ArrayList al = new ArrayList<>();//右边的泛型自动反射进来
al.add(new Person("abc1"));
al.add(new Person("abc2"));
al.add(new Person("abc3"));
// printColl(al);
ArrayList al1 = new ArrayList();
al1.add(new Student("abc--1"));
al1.add(new Student("abc--2"));
al1.add(new Student("abc--3"));
printColl(al1);
}
public static void printColl(Collection extends Person> al) {
Iterator extends Person> it = al.iterator();
while (it.hasNext()) {
System.out.println(it.next().getName());
}
}
/*public static void printColl(ArrayList> al)
{
Iterator> it = al.iterator();
while (it.hasNext()) {
System.out.println(it.next().toString());
}
}*/
}
class Person {
private String name;
Person(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
class Student extends Person {
Student(String name) {
super(name);
}
}
/*
class Student implements Comparable {
public int compareTo(Person s){
this.getName()
}
}
*/
/*
class Comp implements Comparator{ // super E>
public int compare(Person s1,Person s2) {
//Person s1 = new Student("abc1");
return s1.getName().compareTo(s2.getName());
}
}
TreeSet ts = new TreeSet(new Comp());//TreeSet(Comparator super E> comparator)
ts.add(new Student("abc1"));
ts.add(new Student("abc2"));
ts.add(new Student("abc3"));
*/ 总结










