Java泛型——帮助你更好的读懂源码<dog>
泛型
泛型就相当于集合的标签,我们在使用集合<>
的时候,就是在使用泛型
要知道的是在jdk1.5以前我们只能把集合中的元素设计为Object,之后引入了泛型的概念来解决,我们把元素的类型设计成一个参数,这个类型参数就叫做泛型。
为啥要有泛型
我们假设没有泛型会出现哪种情况,Object类型,是不是啥都能存放?少了限制
package fanxing;
import java.util.ArrayList;
public class text01 {
public static void main(String[] args) {
ArrayList id = new ArrayList<>();
id.add(1);
id.add(2);
id.add(3);
id.add(4);
id.add("ymm");//误存放
for(Object obj : id){
System.out.println(obj);
}
}
}
缺点:集合中可能出现不同类型的数据,不便于管理
添加泛型后:
package fanxing;
import java.util.ArrayList;
public class text01 {
public static void main(String[] args) {
ArrayList<Integer> id = new ArrayList<Integer>();
id.add(1);//自动装箱了
id.add(2);
id.add(3);
id.add(4);
//id.add("ymm");会报错
for(Object obj : id){
System.out.println(obj);
}
for(Integer i : id){
System.out.println(i);
}
}
}
优点:在编译初期就进行检查,不会出现后续的数据类型错误
就是将E给确定为Integer类型
泛型对应的数据类型: 都是引用数据类型,不能是基本数据类型,因为泛型本来就是给集合服务的,集合是引用数据类型,那么泛型自然也就是引用数据类型了,hh
简便写法:
ArrayList<Integer> id = new ArrayList<>();
泛型接口
对于初次接触泛型的小伙伴,可能有点懵,啥是泛型接口?
参考上面这个源码中的<E>
这就是一个泛型接口,下面我们来手写一个泛型接口(学习这个东西,方便我们来看懂源码
public class Text1{
}
public class Text2<E> {
}
- Text1就是一个普通类
- Text2就是一个泛型类
- <>里面就是一个参数类型,这个类型是不确定的,起到一个占位的作用
- 里面像源码中一样也是引用数据类型
package fanxing;
import java.util.ArrayList;
public class text01 {
public static void main(String[] args) {
Text a = new Text();
a.aa("jjjjj");
}
public static class Text<E> {
int a;
int b;
public void aa(E a){
System.out.println(a);
}
}
}
我们可以说是,如果在实例化的时候不指定数据类型,默认为Object类型
来看如果我们在实例化的时候指定数据类型呢?
package fanxing;
import java.util.ArrayList;
public class text01 {
public static void main(String[] args) {
Text<Integer> a = new Text();
a.aa(1111);
}
public static class Text<E> {
int a;
int b;
public void aa(E w){
System.out.println(w);
}
}
}
继承中的泛型接口
package fanxing;
import java.util.ArrayList;
public class text01 {
public static void main(String[] args) {
Text01 son = new Text01();
son.aa(123);
}
public static class Text<E> {
public void aa(E a){
System.out.println(a);
}
}
public static class Text01 extends Text<Integer>{
}
}
指定父类中的泛型,子类中无需再指定泛型,可以直接继承自父类中指定好的泛型,那么既然有指定好的,那么我们来看一下没有指定好的泛型是什么情况?
hh,红色报错! 如果父类不明确指定泛型,那么子类也会变成一个泛型类,这个E的类型可以在创建子类对象的时候确定
这像不像ArrayList中的源码呢?
泛型方法
这里有一个比较容易混淆的概念,泛型方法。
这是不是一个泛型方法呢?不是!并不是带泛型就是泛型方法
泛型方法的参数类型无关于当前类的泛型,我们通过下面的代码来看一下!
public static class Text<E> {
//不是泛型方法
public void aa(E a){
System.out.println(a);
}
//是泛型方法
public <W> void W(W b){
}
}
假设当前的类就没泛型,那么我们第一种写法就是正确的
调用泛型方法
package fanxing;
import java.util.ArrayList;
public class text01 {
public static void main(String[] args) {
Text t= new Text();
t.W("j");
}
public static class Text<E> {
//不是泛型方法
public void aa(E a){
System.out.println(a);
}
//是泛型方法
public static <W> void W(W b){
//泛型方法可以是静态方法
System.out.println("我是泛型方法");
}
}
}
相关文章
- 15个问题自查你真的了解java编译优化吗?
- 实现服务器和客户端数据交互,Java Socket有妙招
- 世界杯专题看板丨今晚8点开战,数据先睹为快!
- Crack App | 某合伙人登录参数 apisign 逻辑分析
- Crack App | 某都市魔幻 FM 请求参数 sign 的加密分析
- Crack App | 某赢+ 二手车 App 登录参数加密逻辑分析
- RocketMQ: 技术架构与启动流程
- 目前社区关于ServiceMesh的主要方向
- k8s的架构是怎么变成现在这个样子
- Envoy的lib库拓扑关系
- 转发“Istio共享代理新模式Ambient Mesh”
- 如何设计属于你自己的秒杀系统?
- 如何把Java代码玩出花?JVM Sandbox入门教程与原理浅谈
- 删错了文件怎么办,文件快速恢复
- ChatGPT 浏览器插件实现思路解析
- 存储系统中的算法:LSM 树设计原理
- 说透游戏中常用的两种随机算法
- 我用消息队列做了一款联机小游戏
- 用算法打败算法
- CRUD 一年多,我的破局思路