import Duixiang4.Duotai.Person;
/**
* 当做一些集合的统一操作的时候,需要保证集合的类型是统一的,此时需要泛型来进行限制
* 优点:
* 1、数据安全
* 2、获取数据时效率比较高
* 给集合中的元素设置相同的类型就是泛型的基本需求
* 使用:
* 在定义对象的时候,通过<>中设置合理的类型来进行实现
* 泛型的高阶应用:
* 1、泛型类
* 在定义类的时候在类名的后面添加<E,K,V,A,B>,起到占位的作用,类中的方法的返回值类型和属性的类型都可以使用
* 2、泛型接口
* 在定义接口的时候,在接口的名称后添加<E,K,V,A,B>,
* 1、子类在进行实现的时候,可以不填写泛型的类型,此时在创建具体的子类对象的时候才决定使用什么类型
* 2、子类在实现泛型接口的时候,只在实现父类的接口的时候指定父类的泛型类型即可,此时,测试方法中的泛型类型必须要跟子类保持一致
* 3、泛型方法
* 在定义方法的时候,指定方法的返回值和参数是自定义的占位符,可以是类名中的T,也可以是自定义的Q,只不过在使用Q的时候需要使用<
* Q>定义在返回值的前面
* 4、泛型的上限(工作中不用)
* 如果父类确定了,所有的子类都可以直接使用
* 5、泛型的下限(工作中不用)
* 如果子类确定了,子类的所有父类都可以直接传递参数使用
*
*/
public class TestFanxing {
public static void main(String[] args) {
FanxingDemo<String> fanxingDemo = new FanxingDemo<String>();
fanxingDemo.setName("小白");
fanxingDemo.setA("15");
fanxingDemo.show();
FanxingDemo<Double> fanxingDemo1 = new FanxingDemo<Double>();
fanxingDemo1.setName("小黑");
fanxingDemo1.setA(18.0);
fanxingDemo1.show();
FanxingDemo<Person> fanxingDemo2 = new FanxingDemo<Person>();
fanxingDemo2.setName("耀");
fanxingDemo2.show();
// List<String> list = new ArrayList<String>();
// list.add("123");
// list.add("true");
// list.add("100L");
// list.add("abc");
// //遍历集合
// //for
// for (int i = 0; i <list.size() ; i++) {
// System.out.println(list.get(i));
// }
// //迭代器
// Iterator<String> iterator = list.iterator();
// while (iterator.hasNext()){
// String next = iterator.next();
// System.out.println(next);
// }
// //增强for循环
// for(String o :list){
// System.out.println(o);
// }
}
}
public class FanxingDemo<A> {
private String name;
private A a ;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public A getA() {
return a;
}
public void setA(A a) {
this.a = a;
}
public void show(){
System.out.println("name:"+name+ "A:"+a);
}
}