摘要:知识点总结泛型知识点总结泛型泛型泛型就是参数化类型适用于多种数据类型执行相同的代码泛型中的类型在使用时指定泛型归根到底就是模版优点使用泛型时,在实际使用之前类型就已经确定了,不需要强制类型转换。
Java知识点总结(Java泛型)
@(Java知识点总结)[Java, Java泛型]
[toc]
泛型泛型就是参数化类型
适用于多种数据类型执行相同的代码
泛型中的类型在使用时指定
泛型归根到底就是“模版”
优点:使用泛型时,在实际使用之前类型就已经确定了,不需要强制类型转换。
泛型主要使用在集合中
import java.util.ArrayList; import java.util.List; public class Demo01 { // 不使用泛型,存取数据麻烦 public static void test1(){ List list = new ArrayList(); list.add(100); list.add("zhang"); /* * 从集合中获取的数据是Object类型,Object类型是所有类型的根类,但是在具体使用的时候需要 * 类型检查,类型转化,处理类型转化异常 * 使用麻烦 */ Object o = list.get(1); if (o instanceof String) { String s = (String)o; } System.out.println(o); } // 使用泛型 public static void test2(){ List自定义泛型 泛型字母list = new ArrayList (); //list.add(100); 放数据时安全检查,100不是String类型,不能存放 list.add("存数据安全,取数据省心"); String s = list.get(0); //取出来的数据直接就是泛型规定的类型 System.out.println(s); } public static void main(String[] args) { test1(); test2(); } }
形式类型参数(formal type parameters)即泛型字母
命名泛型字母可以随意指定,尽量使用单个的大写字母(有时候多个泛型类型时会加上数字,比如T1,T2)
常见字母(见名知意)
T Type
K V Key Value
E Element
当类被使用时,会使用具体的实际类型参数(actual type argument)代替
泛型类只能用在成员变量上,只能使用引用类型
泛型接口只能用在抽象方法上
泛型方法返回值前面加上 <T>
/** * 自定义泛型类 * * 定义"模版"的时候,泛型用泛型字母:T 代替 * 在使用的时候指定实际类型 * * @author Administrator * @param*/ public class Student { private T javase; //private static T javaee; // 泛型不能使用在静态属性上 public Student() { } public Student(T javase) { this(); this.javase = javase; } public T getJavase() { return javase; } public void setJavase(T javase) { this.javase = javase; } } /** * 自定义泛型的使用 * 在声明时指定具体的类型 * 不能为基本类型 * @author Administrator * */ class Demo02 { public static void main(String[] args) { //Student Student = new Student (); //不能为基本类型,编译时异常 Student student = new Student (); student.setJavase(85); System.out.println(student.getJavase()); } }
/** * 自定义泛型接口 * * 接口中泛型字母只能使用在方法中,不能使用在全局常量中 * * @author Administrator * @param*/ public interface Comparator { //public static final T1 MAX_VALUE = 100; //接口中泛型字母不能使用在全局常量中 //T1 MAX_VALUE; public static final int MAX_VALUE = 100; void compare(T2 t); T2 compare(); public abstract T1 compare2(T2 t); }
import java.io.Closeable; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.util.List; /** * 非泛型类中定义泛型方法 * @author Administrator * */ public class Method { // 泛型方法,在返回类型前面使用泛型字母 public static泛型的继承void test1(T t){ System.out.println(t); } // T 只能是list 或者list 的子类 public static void test2(T t){ t.add("aa"); } // T... 可变参数 ---> T[] public static void test3(T...a) { for (T temp : a) { try { if (null != temp) { temp.close(); } } catch (Exception e) { e.printStackTrace(); } } } public static void main(String[] args) throws FileNotFoundException { test1("java 是门好语言"); test3(new FileInputStream("a.txt")); } }
/** * 泛型继承 * * 保留父类泛型 ----》泛型子类 * 不保留父类泛型 -----》子类按需实现 * * 子类重写父类的方法,泛型类型随父类而定 子类使用父类的属性,该属性类型随父类定义的泛型 * * @author Administrator * * @param* @param */ public abstract class Father { T1 age; public abstract void test(T2 name); } // 保留父类泛型 ----》泛型子类 // 1)全部保留 class C1 extends Father { @Override public void test(T2 name) { } } // 2) 部分保留 class C2 extends Father { @Override public void test(Integer name) { } } // 不保留父类泛型 -----》子类按需实现 // 1)具体类型 class C3 extends Father { @Override public void test(Integer name) { } } // 2)没有具体类型 // 泛型擦除:实现或继承父类的子类,没有指定类型,类似于Object class C4 extends Father { @Override public void test(Object name) { } }
/** * 泛型擦除 * 类似于Object,不等于Object * @author Administrator * */ public class Demo03 { public static void test(Student通配符student){ student.setJavase(100); } public static void main(String[] args) { // 泛型擦除 Student student = new Student(); test(student); Student
通配符(Wildcards)
T、K、V、E 等泛型字母为有类型,类型参数赋予具体的值
?未知类型 类型参数赋予不确定值,任意类型
只能用在声明类型、方法参数上,不能用在定义泛型类上
/** * 泛型的通配符 类型不确定,用于声明变量或者形参上面 * * 不能使用在类上 或者 new 创建对象上 * @author Administrator * */ public class Demo04 { // 用在形参上 public static void test(List> list) { List> list2; // 用在声明变量上 list2 = new ArrayListextends/super 上限(extends)(); list2 = new ArrayList (); list2 = new ArrayList (); } public static void main(String[] args) { test(new ArrayList ()); test(new ArrayList ()); } }
指定的类必须是继承某个类,或者实现了某个接口(不是implements),即<=
? extends List
下限(super)即父类或本身
? super List
import java.util.ArrayList;
import java.util.List;
/** * extends:泛型的上限 <= 一般用于限制操作 不能使用在添加数据上,一般都是用于数据的读取 * * supper:泛型的上限 >= 即父类或自身。一般用于下限操作 * * @author Administrator * @param泛型嵌套*/ public class Test { private static void test01() { Test t1 = new Test (); Test t2 = new Test (); Test t3 = new Test (); } private static void test02(List extends Fruit> list) { } private static void test03(List super Apple> list) { } public static void main(String[] args) { // 调用test02(),测试 extends <= test02(new ArrayList ()); test02(new ArrayList ()); test02(new ArrayList ()); // test02(new ArrayList ()); Object 不是 Fruit 的子类 ,编译不通过 // 调用test03() ,测试super >= test03(new ArrayList ()); test03(new ArrayList ()); //test03(new ArrayList ()); ReadApple < apple,所以不能放入 } } class Fruit { } class Apple extends Fruit { } class Pear extends Fruit { } class ReadApple extends Apple { }
从外向里取
import java.util.Map.Entry; import java.util.HashMap; import java.util.Map; import java.util.Set; /** * 泛型嵌套 * @author Administrator * */ public class Demo05 { public static void main(String[] args) { Student2student = new Student2 (); student.setScore("优秀"); System.out.println(student.getScore()); //泛型嵌套 School > school = new School >(); school.setStu(student); String s = school.getStu().getScore(); //从外向里取 System.out.println(s); // hashmap 使用了泛型的嵌套 Map map = new HashMap (); map.put("a", "张三"); map.put("b", "李四"); Set > set = map.entrySet(); for (Entry entry : set) { System.out.println(entry.getKey()+":"+entry.getValue()); } } }
public class School{ private T stu; public T getStu() { return stu; } public void setStu(T stu) { this.stu = stu; } }
public class Student2其他{ T score; public T getScore() { return score; } public void setScore(T score) { this.score = score; } }
import java.util.ArrayList; import java.util.List; /** * 泛型没有多态 * 泛型没有数组 * JDK1.7对泛型的简化 * @author Administrator * */ public class Demo06 { public static void main(String[] args) { Fruit fruit = new Apple(); // 多态,父类的引用指向子类的对象 //Listlist = new ArrayList (); //泛型没有多态 List extends Fruit> list = new ArrayList (); //泛型没有数组 //Fruit [] fruits = new Fruit [10]; //ArrayList底层是一个Object[],它放数据的时候直接放,取数据的时候强制类型转化为泛型类型 /*public boolean add(E e) { ensureCapacityInternal(size + 1); // Increments modCount!! elementData[size++] = e; return true; }*/ /*E elementData(int index) { return (E) elementData[index]; }*/ //JDK1.7泛型的简化,1.6编译通不过 List list2 = new ArrayList<>(); } }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/69360.html
摘要:知识点总结反射反射操作泛型知识点总结反射采用泛型擦除的机制来引入泛型。中的泛型仅仅是给编译器使用的,确保数据的安全性和免去强制类型转换的麻烦。 Java知识点总结(反射-反射操作泛型) @(Java知识点总结)[Java, 反射] Java采用泛型擦除的机制来引入泛型。Java中的泛型仅仅是给编译器javac使用的, 确保数据的安全性和免去强制类型转换的麻烦 。但是,__一旦编译完成,...
摘要:当某个类型变量只在整个参数列表的所有参数和返回值中的一处被应用了,那么根据调用方法时该处的实际应用类型来确定。即直接根据调用方法时传递的参数类型或返回值来决定泛型参数的类型。 标签: java [TOC] 本文对泛型的基本知识进行较为全面的总结,并附上简短的代码实例,加深记忆。 泛型 将集合中的元素限定为一个特定的类型。 术语 ArrayList -- 泛型类型 ArrayLis...
摘要:基础部分集合框架接口接口泛型所有集合类都位于包下。集合框架的知识总结集合框架总结接口的使用集合框架总结类的排序问题声明常量的两种方法遍历的四种方法泛型当我们把一个对象放入集合中后,系统会把所有集合元素都当成类的实例进行处理。 Java 基础部分——集合框架 Collection 接口 Map 接口 泛型 所有集合类都位于java.util包下。集合中只能保存对象(保存对象的...
阅读 2826·2021-10-21 09:38
阅读 2715·2021-10-11 10:59
阅读 2968·2021-09-27 13:36
阅读 1632·2021-08-23 09:43
阅读 726·2019-08-29 14:14
阅读 2989·2019-08-29 12:13
阅读 3180·2019-08-29 12:13
阅读 294·2019-08-26 12:24