泛型
在了解集合之前,我们先来了解一下泛型
泛型:参数化类型 将类型作为参数传入<任意单个大写字母 可多个>
1.为什么会有泛型?
早期的Object
类型可以接受任意的对象类型,但是在实际的应用中会存在类型转换的问题,因为存在这种隐患,就提出了泛型来解决这个问题.
2.Java泛型中的标记符
E - Element (在集合中使用,因为集合中存放的是元素)
T - Type(Java 类), S、U、V - 2nd、3rd、4th types
K - Key(键)
V - Value(值)
N - Number(数值类型)
? - 表示不确定的java类型
Object跟这些标记符代表的java类型有啥区别呢?
Object是所有类的根类,任何类的对象都可以设置给该Object引用变量,使用的时候可能需要类型强制转换,但是用使用了泛型T、E等这些标识符后,在实际用之前类型就已经确定了,不需要再进行类型强制转换。
3.泛型方法
你可以写一个泛型方法,该方法在调用时可以接收不同类型的参数。根据传递给泛型方法的参数类型,编译器适当地处理每一个方法调用。
下面是定义泛型方法的规则:
所有泛型方法声明都有一个类型参数声明部分(由尖括号分隔),该类型参数声明部分在方法返回类型之前(在下面例子中的)。
每一个类型参数声明部分包含一个或多个类型参数,参数间用逗号隔开。一个泛型参数,也被称为一个类型变量,是用于指定一个泛型类型名称的标识符。
类型参数能被用来声明返回值类型,并且能作为泛型方法得到的实际参数类型的占位符。
泛型方法体的声明和其他方法一样。注意类型参数只能代表引用型类型,不能是原始类型(像int,double,char的等)。
4.泛型的应用
我们先来看一下不使用泛型的情况
public class CacheDemo<T> {
Object value;//定义一个Object类的数据 value
public Object getValue() {
return value;
}
public void setValue(Object value) {
this.value = value;
}
public static void main(String[] args) {
CacheDemo c=new CacheDemo();
/*
创建对象后,我们传入一个int型的元素123,刚才定义的数据类型时Object类
这时候就需要强转 将数据类型转为int类型,下面同理,传入String类型hello
就转为String类型即可
*/
c.setValue(123);
Integer a=(Integer)c.getValue();
c.setValue("hello");
String b=(String)c.getValue();
}
}
使用泛型处理数据
//在类名后使用泛型<T (泛型名 可以传入多个)>
public class CacheDemo<T> {
T value;//元素value的类型定义为T
public T getValue() {
return value;
}
public void setValue(T value) {
this.value = value;
}
public static void main(String[] args) {
/*
在创建对象时声明该对象的参数类型
CacheDemo<String> c1=new CacheDemo();
*/
CacheDemo<String> c1=new CacheDemo();
c1.setValue("asd");
String value1=c1.getValue();
CacheDemo<Integer> c2=new CacheDemo<>();
c2.setValue(123);
Integer value2=c2.getValue();
System.out.println(value2);
System.out.println(c1.getValue());
}
}
创作不易,大佬们留步… 动起可爱的双手,来个赞再走呗 (๑◕ܫ←๑)