泛型:

一种程序设计语言的新特性,于Java而言,在JDK 1.5开始引入。泛型就是在设计程序的时候定义一些可变部分,在具体使用的时候再给可变部分指定具体的类型。使用泛型比使用Object变量再进行强制类型转换具有更好的安全性和可读性。在Java中泛型主要体现在泛型类、泛型方法和泛型接口中。

泛型类:

当一个类要操作的引用数据类型不确定的时候,可以给该类定义一个形参。用到这个类的时候,通过传递类型参数的形式,来确定要操作的具体的对象类型。在JDK1.5之前,为了提高代码的通用性,通常把类型定义为所有类的父类型:Object,这样做有两大弊端:1. 在具体操作的时候要进行强制类型转换;2. 这样还是指定了类型,还是不灵活,对具体类型的方法未知且不安全。

泛型类的格式:在类名后面声明类型变量<E>   ,泛型类可以有多个类型变量, 如:public class MyClass<K, V>

什么时候使用泛型类?

只要类中操作的引用数据类型不确定,就可以定义泛型类。通过使用泛型类,可以省去强制类型转换和类型转化异常的麻烦。

泛型类例子:

在这里定义两个类:Teacher 和 Student,定义一个泛型类Util<E>,其中getE()的作用是根据传入的对象,返回具体的对象。在main()方法中,传入具体的类型为Student和Teacher,再进一步操作。

  1. public class Generic {
  2. public static void main(String[] args) {
  3. Util<Student> ts = new Util<Student>();
  4. System.out.println(ts.getE(new Student("Student","三年级" ,22)).getGrade());
  5. Util<Teacher> tt = new Util<Teacher>();
  6. System.out.println(tt.getE(new Teacher("Teacher",22)).getName());
  7. }
  8. }
  9. class Util<E>{
  10. public E getE(E e){
  11. return e;
  12. }
  13. }
  14. class Teacher{
  15. String name;
  16. int age;
  17. public Teacher() {
  18. }
  19. public Teacher(String name, int age){
  20. this.name = name;
  21. this.age = age;
  22. }
  23. Some  Getter & Setter functions
  24. }
  25. class Student{
  26. String name;
  27. String grade;
  28. int number;
  29. public Student(String name, String grade, int number){
  30. this.name = name;
  31. this.grade = grade;
  32. this.number = number;
  33. }
  34. Some Getter & Setter functions
  35. }
public class Generic {
public static void main(String[] args) {
Util&lt;Student&gt; ts = new Util&lt;Student&gt;();

        System.out.println(ts.getE(new Student("Student","三年级" ,22)).getGrade());

        Util<Teacher> tt = new Util<Teacher>();

        System.out.println(tt.getE(new Teacher("Teacher",22)).getName());

}

}

class Util<E>{

public E getE(E e){

return e;

}

}

class Teacher{

String name;

int age;

public Teacher() {

}

public Teacher(String name, int age){
this.name = name;
this.age = age;
}
Some Getter &amp; Setter functions

}

class Student{

    String name;

    String grade;

    int number;

    

    public Student(String name, String grade, int number){

        this.name = name;

        this.grade = grade;

        this.number = number;

    }

    Some Getter & Setter functions

    

}


泛型方法:

泛型方法也是为了提高代码的重用性和程序安全性。编程原则:尽量设计泛型方法解决问题,如果设计泛型方法可以取代泛型整个类,应该采用泛型方法。

泛型方法的格式:类型变量放在修饰符后面和返回类型前面, 如:public static <E> E getMax(T... in)

泛型方法例子:

  1. public class GenericFunc {
  2. public static void main(String[] args) {
  3. print("hahaha");
  4. print(200);
  5. }
  6. public static <T> void print(T t){
  7. System.out.println(t.toString());
  8. }
  9. }
public class GenericFunc {
public static void main(String[] args) {
print("hahaha");
print(200);
} public static &lt;T&gt; void print(T t){
System.out.println(t.toString());
}

}

泛型接口:

将泛型原理用于接口实现中,就是泛型接口。

泛型接口的格式:泛型接口格式类似于泛型类的格式,接口中的方法的格式类似于泛型方法的格式。

泛型接口例子:

MyInterface.java

  1. public interface MyInteface<T> {
  2. public T read(T t);
  3. }
public interface MyInteface<T> {
public T read(T t);
}

Generic2.java

  1. public class Generic2 implements MyInterface<String>{
  2. public static void main(String[] args) {
  3. Generic2 g = new Generic2();
  4. System.out.println(g.read("hahaha"));
  5. }
  6. @Override
  7. public String read(String str) {
  8. return str;
  9. }
  10. }
public class Generic2 implements MyInterface<String>{
public static void main(String[] args) {
Generic2 g = new Generic2();
System.out.println(g.read("hahaha"));
} @Override
public String read(String str) {
return str;
}

}

泛型通配符:

当操作的不同容器中的类型都不确定的时候,而且使用的元素都是从Object类中继承的方法,这时泛型就用通配符“?”来表示。

泛型的通配符:“?”  相当于 “? extends Object”

泛型通配符例子:

  1. import java.util.ArrayList;
  2. import java.util.Collection;
  3. import java.util.HashSet;
  4. import java.util.Iterator;
  5. public class AllCollectionIterator {
  6. public static void main(String[] args) {
  7. HashSet<String> s1 = new HashSet<String>();
  8. s1.add("sss1");
  9. s1.add("sss2");
  10. s1.add("sss3");
  11. ArrayList<Integer> a1 = new ArrayList<Integer>();
  12. a1.add(1);
  13. a1.add(2);
  14. a1.add(3);
  15. a1.add(4);
  16. printAllCollection(a1);
  17. System.out.println("-------------");
  18. printAllCollection(s1);
  19. }
  20. public static void printAllCollection(Collection<?> c){
  21. Iterator<?> iter = c.iterator();
  22. while (iter.hasNext()) {
  23. System.out.println(iter.next().toString());
  24. }
  25. }
  26. }
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator; public class AllCollectionIterator {
public static void main(String[] args) {
HashSet&lt;String&gt; s1 = new HashSet&lt;String&gt;();
s1.add("sss1");
s1.add("sss2");
s1.add("sss3"); ArrayList&lt;Integer&gt; a1 = new ArrayList&lt;Integer&gt;();
a1.add(1);
a1.add(2);
a1.add(3);
a1.add(4); printAllCollection(a1);
System.out.println("-------------");
printAllCollection(s1);
} public static void printAllCollection(Collection&lt;?&gt; c){
Iterator&lt;?&gt; iter = c.iterator();
while (iter.hasNext()) {
System.out.println(iter.next().toString()); }
}

}

泛型限定:

泛型限定就是对操作的数据类型限定在一个范围之内。限定分为上限和下限。

上限:? extends E   接收E类型或E的子类型

下限:? super E    接收E类型或E的父类型

限定用法和泛型方法,泛型类用法一样,在“<>”中表达即可。

一个类型变量或通配符可以有多个限定,多个限定用“&”分隔开,且限定中最多有一个类,可以有多个接口;如果有类限定,类限定必须放在限定列表的最前面。如:T extends MyClass1 & MyInterface1 & MyInterface2

在Collection<E>接口中addAll()就用到泛型限定。

addAll(Collection<?
extends E> c)


          将指定 collection 中的所有元素都添加到此 collection 中(可选操作)。

泛型限定的例子:

这个例子的作用是计算最大值。

  1. import java.util.Calendar;
  2. import java.util.GregorianCalendar;
  3. public class GenericGetMax {
  4. public static void main(String[] args) {
  5. String[] inArrStr = {"haha", "test", "nba", "basketball"};
  6. System.out.println(GetMax.findMax(inArrStr).toString());
  7. Integer[] inArrInt = {11, 33, 2, 100, 101};
  8. System.out.println(GetMax.findMax(inArrInt));
  9. GregorianCalendar[] inArrCal = {
  10. new GregorianCalendar(2016, Calendar.SEPTEMBER, 22),
  11. new GregorianCalendar(2016, Calendar.OCTOBER, 10)};
  12. System.out.println(GetMax.findMax(inArrCal).toZonedDateTime());
  13. }
  14. }
  15. class GetMax {
  16. @SafeVarargs
  17. public static <T extends Comparable> T findMax(T... in) {
  18. T max = in[0];
  19. for (T one : in) {
  20. if (one.compareTo(max) > 0) {
  21. max = one;
  22. }
  23. }
  24. return max;
  25. }
  26. }
import java.util.Calendar;
import java.util.GregorianCalendar; public class GenericGetMax {
public static void main(String[] args) {
String[] inArrStr = {"haha", "test", "nba", "basketball"};
System.out.println(GetMax.findMax(inArrStr).toString());
Integer[] inArrInt = {11, 33, 2, 100, 101};
System.out.println(GetMax.findMax(inArrInt));
GregorianCalendar[] inArrCal = {
new GregorianCalendar(2016, Calendar.SEPTEMBER, 22),
new GregorianCalendar(2016, Calendar.OCTOBER, 10)};
System.out.println(GetMax.findMax(inArrCal).toZonedDateTime());
}

}

class GetMax {

@SafeVarargs

public static <T extends Comparable> T findMax(T... in) {

T max = in[0];

for (T one : in) {

if (one.compareTo(max) > 0) {

max = one;

}

}

	return max;
}

}

Java 泛型-泛型类、泛型方法、泛型接口、通配符、上下限的更多相关文章

  1. java 泛型 -- 泛型类,泛型接口,泛型方法

    泛型T泛型的许多最佳例子都来自集合框架,因为泛型让您在保存在集合中的元素上指定类型约束.在定义泛型类或声明泛型类的变量时,使用尖括号来指定形式类型参数.形式类型参数与实际类型参数之间的关系类似于形式方 ...

  2. Java 基础 - 泛型类/泛型方法/类型通配符'?' 的用法及栗子

    笔记: /**1.定义一个PairTest泛型类, 测试泛型 类 Pair的用法 * class Pair<T>{ * private T first; * private T secon ...

  3. java泛型-泛型类,泛型接口,常用形式

    泛型简单使用: package com.etc; import java.util.ArrayList; import java.util.List; /* 泛型就相当于<>一个标签,泛化 ...

  4. Java泛型解析(02):通配符限定

    Java泛型解析(02):通配符限定      考虑一个这种场景.计算数组中的最大元素. [code01] public class ArrayUtil { public static <T&g ...

  5. Java 泛型示例 - 泛型方法,类,接口

    Java Genrics 是 Java 5 中引入的最重要的功能之一. 如果您一直在使用Java Collections并使用版本 5 或更高版本,那么我确定您已经使用过它. Java 中具有集合类的 ...

  6. java泛型-自定义泛型方法与类型推断总结

    下面是自定义泛型方法的练习: package com.mari.generic; import java.util.ArrayList; import java.util.Collection; im ...

  7. Java泛型之上、下界通配符的理解(适合初学)

    泛型的由来 为什么需要泛型   Java的数据类型一般都是在定义时就需要确定,这种强制的好处就是类型安全,不会出现像弄一个ClassCastException的数据给jvm,数据安全那么执行的clas ...

  8. JAVA泛型之<? extends T>:(通配符上限)和<? super T>(通配符下限)

    一.通配符上限和通配符下限接受的类型 通配符上限:<? extends T> 通配符下限:<? super T> 以下代码是测试结果,注释为解释说明 package xayd. ...

  9. Java泛型(2):泛型接口

    泛型不仅可以在类上实现,也可以在接口上实现.JDK中[Iterable<T> <-- Collection<E> <-- List<E>/Queue&l ...

随机推荐

  1. SSH无password登陆配置

    摘录一 在192.168.42.142机器上 1)执行:ssh-keygen -t rsa 2)然后拍两下回车(均选择默认) 3)执行: ssh-copy-id -i /root/.ssh/id_rs ...

  2. PipeCAD之管道标准库PipeStd

    PipeCAD之管道标准库PipeStd eryar@163.com Key Words. PipeCAD, PipeStd, 管道设计软件,管件库 1. Introduction 前不久,两位老友徐 ...

  3. 64。node.js 中间件express-session使用详解

    转自:http://jinjiakarl.com/2018/06/09/node-js-%E4%B8%AD%E9%97%B4%E4%BB%B6express-session%E4%BD%BF%E7%9 ...

  4. 56.如何清除已经设置的npm config配置

    npm config delete registry npm config delete disturl 或者 npm config edit 找到淘宝那两行,删除

  5. js -- canvas img 封装

    鼠标   1.操作canvas 中的 img. 右键放大缩小,左键移动img. 2.拖动input type= range  改变图片的透明度 html 代码 <!DOCTYPE html> ...

  6. 【深入篇】Android常用布局方式简介

    LinearLayout 线性布局是程序中最常见的布局方式.一般分为水平线性布局和竖直线性布局,通过android.orientation属性可以设置线性布局的方向. 在布局中操作颜色时,要用的是十六 ...

  7. Autoencoders and Sparsity(二)

    In this problem set, you will implement the sparse autoencoder algorithm, and show how it discovers ...

  8. celery work logging 问题

    celery 的日志里只输出日志 不输入标准打印

  9. GCC中-fpic解惑(转载)

    参考: 1.<3.18 Options for Code Generation Conventions>2.<Options for Linking>3.<GCC -fP ...

  10. android图像处理系列之七--图片涂鸦,水印-图片叠加

    图片涂鸦和水印其实是一个功能,实现的方式是一样的,就是一张大图片和一张小点图片叠加即可.前面在android图像处理系列之六--给图片添加边框(下)-图片叠加中也讲到了图片叠加,里面实现的原理是直接操 ...