博客
关于我
泛型2(Java)
阅读量:288 次
发布时间:2019-03-01

本文共 2273 字,大约阅读时间需要 7 分钟。

文章目录

1.泛型类的使用–通配符

  • 通配符,和类型边界有点像,也是限制泛型参数传入的条件,是在泛型类的使用的时候涉及的,尤其是泛型类作为某个方法的参数的时候涉及的。

1.1基本

  • ?用于泛型的使用,即为通配符
public class MyArray
{ }//可以传入任意类型的MyArraypublic static void printAll(MyArray
m){ }//以下调用都是正确的printAll(new MyArray
());printAll(new MyArray
());printAll(new MyArray
());printAll(new MyArray
());printAll(new MyArray
());

1.2 通配符-上界

语法

示例:

//传入的类型实参是Animal子类的任意类型的MyArraypublic static void printAll(MyArray
m){ }//以下的调用都是正确的printAll(new MyArray
());printAll(new MyArray
());printAll(new MyArray
());//以下的调用是编译错误的printAll(new MyArray
());printAll(new MyArray
());

注意: 需要区分泛型使用中的通配符上界和泛型定义中类型的上界。

1.3通配符–下界

语法

**示例: **

//可以传入类型实参Cat父类的任意类型的MyArraypublic static void printAll(MyArray
list>{ }//以下的调用都是正确的printAll(new MyArrayList
());printAll(new MyArrayList
());println(new MyArrayList
());//以下的调用是编译错误的printAll(new MyArrayList
());printAll(new MyArrayList
());

2 泛型中的父子类型

public class MyArray
{ }//Object是Animal的父类,Animal是Cat Dog的父类//MyArray
不是MyArray
的父类型//MyArray
也不是MyArray
的父类型//需要使用通配符来确定父子关系MyArray
是MyArray
的父类型MyArray
是MyArrayList
的父类型

示例:

public class Mian{   	public static void main(String [] args){   		func3(new MyArray2
()); } public static void func1(MyArray2
a1){ //啥也不用干 } public static void func2(MyArray
a2){ MyArray2
a1=a2; func1(a2); } public static void func3(MyArray2
a3){ //此处方法的调用,就相当于 //符合向上转型的要求 MyArray2
a2=a3; func2(a3); }}

3.泛型方法

3.1语法格式

方法限定符 <类型形参列表> 返回值类型 方法名称(形参列表){}

3.2示例

public class Main{   	public static 
void swap (E [] arr,int i,int j){ E t = arr[i]; arr[i] = arr[j]; arr[j] = t; }}//没有显示指定类型,编译期间需要进行类型推导Integer [] a={ ...};swap(a,0,9);//显式的指定类型,编译期间不需要进行类型推导String [] b={ };Main.
swap(b,0,9);

4.泛型的优缺点

泛型的优点:

  • 提高代码的复用性

  • 提高开发效率

  • 可以实现一些通用类型的容器或算法

    泛型的缺点:

  • 泛型类型的参数不支持基本数据类型的

  • 无法实例化泛型类型的对象

  • 无法使用泛型类型声明静态的属性

  • 无法使用instanceof判断带参数类型的泛型类型

  • 无法创建泛型数组

  • 无法create catch throw 一个泛型类异常(异常不支持泛型)

  • 泛型类型不是形参的一部分,无法重载。

转载地址:http://btsa.baihongyu.com/

你可能感兴趣的文章
mysql 网络目录_联机目录数据库
查看>>
MySQL 聚簇索引&&二级索引&&辅助索引
查看>>
Mysql 脏页 脏读 脏数据
查看>>
mysql 自增id和UUID做主键性能分析,及最优方案
查看>>
Mysql 自定义函数
查看>>
mysql 行转列 列转行
查看>>
Mysql 表分区
查看>>
mysql 表的操作
查看>>
mysql 视图,视图更新删除
查看>>
MySQL 触发器
查看>>
mysql 让所有IP访问数据库
查看>>
mysql 记录的增删改查
查看>>
MySQL 设置数据库的隔离级别
查看>>
MySQL 证明为什么用limit时,offset很大会影响性能
查看>>
Mysql 语句操作索引SQL语句
查看>>
MySQL 误操作后数据恢复(update,delete忘加where条件)
查看>>
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>