标签:work ret show com stat ase compare 接收 setname
三、泛型概述和基本使用
* A:泛型概述
* 泛型的由来:通过Object转型问题引入
* 早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题。也就存在这隐患,所以Java提供了泛型来解决这个安全问题。
1 /*Person类 父类*/
2 public class Person {
3 private String name;
4 private int age;
5 public Person() {
6 super();
7
8 }
9 public Person(String name, int age) {
10 super();
11 this.name = name;
12 this.age = age;
13 }
14 public String getName() {
15 return name;
16 }
17 public void setName(String name) {
18 this.name = name;
19 }
20 public int getAge() {
21 return age;
22 }
23 public void setAge(int age) {
24 this.age = age;
25 }
26
27 }
28
29 /*Student 类继承Person类*/
30 public class Student extends Person {
31
32 public Student() {
33 }
34
35 public Student(String name, int age) {
36 super(name, age);
37
38 }
39
40 }
41 /*Tool class*/
42
43 public class Tool {
44 private Object q;
45
46 public Object getObj() {
47 return q;
48 }
49
50 public void setObj( ) {
51 this.q = q;
52 }
53
54
55 }
56
57 /*Work class extends Person*/
58 public class Worker extends Person {
59
60 public Worker() {
61 }
62
63 public Worker(String name, int age) {
64 super(name, age);
65
66 }
67
68 }
69
70
71 /*invoke class*/
72 public static void demo1() {
73 Tool t = new Tool (); //创建工具类对象
74 t.setObj(new Student("张三",23));
75
76 //Worker w = (Worker) t.getObj(); //向下转型,但是
77 //Object是超类无法转型
78 //System.out.println(w);
79 }
80
81 /**
82 上方会报错,因为传入是Student类型但是接受的是Work类型,导致类型不一致
83 解决办法是用泛型指定Tool是Student类,这样就可以实现强转
84 */
解决方法:
public static void demo1() { Tool<Student> t = new Tool<>(); //创建工具类对象 t.setObj(new Student("张三",23)); //Worker w = (Worker) t.getObj(); //向下转型 //System.out.println(w); } /* improve Tool class*/ public class Tool<Q> { private Q q; public Q getObj() { return q; } public void setObj(Q q) { this.q = q; } }
扫盲点:
public class Tool<Q> { private Q q; public Q getObj() { return q; } public void setObj(Q q) { this.q = q; } public<T> void show(T t) { //方法泛型最好与类的泛型一致 System.out.println(t); //如果不一致,需要在方法上声明该泛型 } public static<W> void print(W w) { //静态方法必须声明自己的泛型 System.out.println(w); }
在接口中实现泛型
interface Inter<T> { public void show(T t); } /*class Demo implements Inter<String> { //推荐用这种 @Override public void show(String t) { System.out.println(t); } }*/ class Demo<T> implements Inter<T> { //没有必要在实现接口的时候给自己类加泛型 @Override public void show(T t) { System.out.println(t); } }
泛型中高级通配符的运用
/**
* * A:泛型通配符<?>
* 任意类型,如果没有明确,那么就是Object以及任意的Java类了
* B:? extends E
* 向下限定,E及其子类
* C:? super E
* 向上限定,E及其父类
*/
B:
1 public static void main(String[] args) { 2 //List<?> list = new ArrayList<Integer>(); //当右边的泛型是不确定时,左边可以指定为? 3 ArrayList<Person> list1 = new ArrayList<>(); 4 list1.add(new Person("张三", 23)); 5 list1.add(new Person("李四", 24)); 6 list1.add(new Person("王五", 25)); 7 8 ArrayList<Student> list2 = new ArrayList<>(); 9 list2.add(new Student("赵六", 26)); 10 list2.add(new Student("周七", 27)); 11 12 list1.addAll(list2); 13 System.out.println(list1); 14 15 }
C:
1 public static void main(String[] args) { 2 //demo1(); 3 TreeSet<Student> ts1 = new TreeSet<>(new CompareByAge()); 4 ts1.add(new Student("张三", 33)); 5 ts1.add(new Student("李四", 13)); 6 ts1.add(new Student("王五", 23)); 7 ts1.add(new Student("赵六", 43)); 8 9 TreeSet<BaseStudent> ts2 = new TreeSet<>(new CompareByAge()); 10 ts2.add(new BaseStudent("张三", 33)); 11 ts2.add(new BaseStudent("李四", 13)); 12 ts2.add(new BaseStudent("王五", 23)); 13 ts2.add(new BaseStudent("赵六", 43)); 14 15 System.out.println(ts2); 16 } 17 18 // public static void demo1() { 19 // ArrayList<Student> list1 = new ArrayList<>(); 20 // list1.add(new Student("张三", 23)); 21 // list1.add(new Student("李四", 24)); 22 // 23 // ArrayList<BaseStudent> list2 = new ArrayList<>(); 24 // list2.add(new BaseStudent("王五", 25)); 25 // list2.add(new BaseStudent("赵六", 26)); 26 // 27 // list1.addAll(list2); 28 // } 29 30 31 32 33 class CompareByAge implements Comparator<Student> { 34 35 @Override 36 public int compare(Student s1, Student s2) { 37 int num = s1.getAge() - s2.getAge(); 38 return num == 0 ? s1.getName().compareTo(s2.getName()) : num; 39 } 40 41 }
B,C 原理解释图
* B:泛型好处
* 提高安全性(将运行期的错误转换到编译期)
* 省去强转的麻烦
* C:泛型基本使用
* <>中放的必须是引用数据类型
* D:泛型使用注意事项
* 前后的泛型必须一致,或者后面的泛型可以省略不写(1.7的新特性菱形泛型)
标签:work ret show com stat ase compare 接收 setname
原文地址:https://www.cnblogs.com/CMUT/p/8847790.html