【java笔记】泛型定义和使用


转:https://blog.csdn.net/m0_52043808/article/details/123137339

为什么使用泛型

泛型的字面意思就是广泛的类型。利用泛型,同一套代码可以用于多种数据类型, 这样,不仅可以复用代码,降低耦合,而且可以提高代码的可读性和安全性

可读性:var s=new ArrayList<String>();

安全性:

(1)编译器可以检查,防止插入错误类型的对象。即把运行时出现的强制类型转换异常提前到编译器异常。

ArrayList<String>list=new ArrayList<>();
list.add(“abc”);
list.add(1);//报错
(2)ArrayList内部如果不使用类型参数,而使用Object数组,那么当获取一个值时必须进行强制类型转换。当使用向下转型并且对象数据类型不同时会出错。

安全性(2)代码

//缺省默认为Object类型
ArrayList list=new ArrayList();
list.add(“a”);
list.add(1);

Iterator it=list.iterator();
while(it.hasNext()){
Object obj=it.next();
如果想要使用对象的方法,必须使用强制类型转换.
}
//坏处:不能调用对象的方法(向上转型),当使用向下转型并且对象数据类型不同时会出错
学习泛型的用处:排除代码的问题,读懂集合类内部工作原理

 

String作为参数赋值给E

定义泛型类:修饰符 class 类名<类型变量>

类型遍历:在类定义中用于指定方法的返回类型以及字段和局部变量的类型

<T>,<T,U,….>

可以用具体的类型变量来实例化泛型类型

可以说,泛型类相当于普通类的工厂

public class fanxing <E>{
private E name;
public fanxing() {
}
public fanxing(E name) {
this.name = name;
}
public E getName() {
return name;
}
public void setName(E name) {
this.name = name;
}
}

public class Demp {
public static void main(String[] args) {
fanxing<String>f1=new fanxing<>();
f1.setName(“a”);
System.out.println(f1.getName());
fanxing<Integer>f2=new fanxing<>();
f2.setName(1);
System.out.println(f2.getName());

}
}
创建集合对象的时候,会确定泛型的数据类型

定义和使用含有泛型的方法:
修饰符<代表泛型的变量>返回值类型 方法名(参数){}

public class fanxing{
//定义含有一个泛型的方法
public<M>void method(M m){
System.out.println(m);
}
}
public class Demp {
public static void main(String[] args) {
fanxing f1=new fanxing();
f1.method(“asd”);
f1.method(1);
f1.method(1.2);
f1.method(true);
}
}
定义含有泛型的静态方法
静态方法通过类直接调用

public class fanxing{
//定义含有一个泛型的方法
public static <M>void method(M m){
System.out.println(m);
}
}
public class Demp {
public static void main(String[] args) {
fanxing.method(“1234”);
}
}

定义含有泛型的接口
一.接口的实现类确定泛型的类型
public interface fanxing<I>{
void method(I i);
}
public class faxingimp implements fanxing<String>{
@Override
public void method(String s) {
System.out.println(s);
}
}
public class Demp {
public static void main(String[] args) {
faxingimp f1=new faxingimp();
f1.method(“ss”);
}
}

二.接口的实现类使用和抽象类一样的泛型,在创建实现类对象时确定数据类型
public interface fanxing<I>{
void method(I i);
}
public class faxingimp<I> implements fanxing<I>{
@Override
public void method(I i) {
System.out.println(i);
}
}
public class Demp {
public static void main(String[] args) {
faxingimp f1=new faxingimp();
f1.method(“ss”);
f1.method(1);

}
}

泛型通配符
?代表任意的数据类型

使用:不能创建对象使用,只能作为方法的参数使用

例:定义一个方法能遍历所有类型的Arraylist集合

public static void printArray(ArrayList<?>list){
//使用迭代器遍历
Iterator<?>it=list.iterator();
while(it.hasNext()){
Object o=it.next();
Sout(o);
}
}
(要求能看到源码即可)
泛型的上限限定:
?extends E代表使用的泛型只能是E类型的子类/本身

泛型的下限限定:
? super E代表使用的泛型只能是E类型父类/本身

 

————————————————
版权声明:本文为CSDN博主「暮色_年华」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_52043808/article/details/123137339

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/289786.html

(0)
上一篇 2022年9月16日
下一篇 2022年9月16日

相关推荐

发表回复

登录后才能评论