博客
关于我
Java 泛型使用
阅读量:376 次
发布时间:2019-03-05

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

当我们解析 json 时, 期望通过参数传入目标类, 得到返回值对象类型就是目标类的类型, 从而省掉类型转换的操作, 这时就可以利用泛型

/** * 方法上泛型的语法:  * 在返回值前面使用尖括号, 里面是泛型, 表示某个类型 * 这里方法参数是 Class
返回值是 T, 表示传入某个类对象, 返回值可以拿到该类的实例对象 */public static
T parse(String text, Class
clazz) { try { return JSON.parseObject(text, clazz); } catch (Exception e) { log.error("json 解析出错: {}", text); log.error(e.getMessage(), e); return null; }}

其他泛型常识

  • 泛型可以声明在接口 / 类 / 方法上
  • 声明在类上后, 实例方法可以直接使用泛型无需再次声明, 不过类方法不能使用类上的泛型, 需要每次自己手动声明泛型
  • 泛型出现在编译期, 好处是减少强制类型转换和提升阅读性
  • 泛型可以限定于某个类 / 接口的父类 / 子类, 例如 <E extends DemoData> 表示继承 / 实现 DemoData 的类才能编译通过; <E super DemoData> 表示子类 / 子接口是 DemoData 的类才能编译通过
  • 泛型有通配符 <?>, 这种数据取到默认都是 Object 类型

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

你可能感兴趣的文章
mysql架构简介、及linux版的安装
查看>>
MySQL查看数据库相关信息
查看>>
MySQL查看表结构和表中数据
查看>>
MySQL查询优化:LIMIT 1避免全表扫描
查看>>
MySQL查询优化之索引
查看>>
mysql查询储存过程,函数,触发过程
查看>>
mysql查询总成绩的前3名学生信息
查看>>
mysql查询慢排查
查看>>
MySQL查询报错ERROR:No query specified
查看>>
mysql查询数据库储存数据的占用容量大小
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
MySQL查询结果排序
查看>>
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>