JAVA影子变量,Java之路--Javase篇   泛型

泛型

我们在使用Collection集合存储自定义对象时,经常会使用自定义对象的特有方法,而当对象传入Collection时会自动提升为Object类型,那么在使用对象特有方法时必须将其向下强转。由于一个Collection集合中可以存储不同类型的对象,当被暴露出去编程者扔进去的对象并不instanceOf前面的对象而出现强转抛出ClassCastException异常。因此在jdk1.5中出现泛型解决此问题。

表现形式:

泛型优点:将运行时期的问题ClassCastException转移到编译期;避免了强转转换的麻烦。

使用条件:只要使用的接口或者类旁边有<>,就需要使用。

泛型原理:<>就是用于定义形式参数,当使用带有<>的类和接口时,就需要将具体的实际参数也就具体的类型传递给<>,简单的说泛型就是类型参数传递。而且泛型应用于编译时期的技术,用于检测操作的引用数据类型编译时,检测完具体的类型后,如果没有编译失败,所生成的class文件中就没有泛型了。这就叫泛型擦除。既然都已经擦除了如何知道获取元素时具体的类型呢?解决方案,就是可以通过存入的元素获取该元素的类型(Object的getClass方法)。应用该类型对所取出的对象进行具体类型的指定。这个称之为泛型的补偿。

泛型类

在自定义的类上加上泛型:任意对象的工具类是老方式,因为在使用对象自己特有方法时需要将其从Object强制向下转换。jdk1.5后出现泛型后,当我们使用工具类需要操作什么类型就指定什么类型。在定义工具类时,具体操作类型不确定时,就定义一个类型变量接收这个类型即可,让使用者传入具体的操作对象类型。

class Tool

{

private QQ obj;

public void setObject(QQ obj)

{

this.obj = obj;

}

}

class GenericDemo3

{

public static void main(String[] args)

{

Tool t = new Tool();

--------

}

}

泛型使用条件:当类中的操作的引用数据类型不确定时。

泛型方法:

class Demo

{

public  void show(Q q)//show 方法要操作的类型一定要和Demo对象指定的类型

//致

{

System.out.println(“show:”+q);

}

public void print(T q)//print方法不用和Demo对象指定的类型一致

{

System.out.println(“print:”+q);

}

public static void method(z q)//在Static方法时静态方法是不可能访问类上的定义的泛型。故静态方法需要使用泛型必须将泛型定义在方法上。另外,泛型定义在方法上时,必须将泛型定义在返回值类型前面修饰符后面。

{

System.out.println(“method:”+q);

}

}

Class GenericDemo

{

public static void main(String[] args)

{

Demo d = new Demo();

Demo.print(“Dada!”);

}

}

注意:泛型方法中,不可以使用泛型接收到的具体类型的特有功能。因为要操作的类型不确定不能使用具体功能,因为在泛型擦除时,泛型方法定义都是Object。所以只能使用Object类中的方法,因为这些方法所有对象都具备。可以将泛型理解成Object类使用的一种扩展。

泛型接口:

interface Iner

{

public void show(T t);

}

//对象实现接口明确接口具体类型

/**calss InterImp implements Inter

{

public void show(String s)

{

System.out.println(“show:”+s);

}

}

*/

//对象在实现接口时,也不明确具体类型。

class InterImpl implements Inter

{

public void show(T t)

{

System.out.println(t);

}

}

class GenericDemo

{

public static void main(String[] args)

{

InterImpl i = new InerImpl ();

i.show(“abc”);

}

}

泛型通配符:当元素类型不确定时,可以用?来标识泛型;当需要操作集合中的元素均是某一个类(person)的子类(Student、worker等)则就是说需要对集合中的对象类型进行限定:

?extends E代表只能接收E类型或者其子类型。此时是则可以调用E的方法,为何也可以调用E子类的特有方法呢?;

?super E 代表只能接收E类型或者其所有父类型;

泛型使用注意事项:

ArrayList li = new ArryList();//error

ArrayList li = new ArryList();// error

ArrayList extends Object> li = new ArrayList();

li.add(“String!”);//error

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值