java原始类型_Java™ 教程(泛型原始类型)

泛型原始类型

原始类型是没有任何类型参数的泛型类或接口的名称,例如,给定Box泛型类:

public class Box {

public void set(T t) { /* ... */ }

// ...

}

要创建参数化类型的Box,请为形式类型参数T提供实际类型参数:

Box intBox = new Box<>();

如果省略实际的类型参数,则创建一个原始类型Box:

Box rawBox = new Box();

因此,Box是泛型Box的原始类型,但是,非泛型类或接口类型不是原始类型。

原始类型出现在遗留代码中,因为许多API类(例如Collections类)在JDK 5.0之前不是泛型的,使用原始类型时,你实际上获得预泛型行为 — Box会为你提供Object,为了向后兼容,允许将参数化类型分配给其原始类型:

Box stringBox = new Box<>();

Box rawBox = stringBox; // OK

但是,如果将原始类型分配给参数化类型,则会收到警告:

Box rawBox = new Box(); // rawBox is a raw type of Box

Box intBox = rawBox; // warning: unchecked conversion

如果使用原始类型调用相应泛型类型中定义的泛型方法,也会收到警告:

Box stringBox = new Box<>();

Box rawBox = stringBox;

rawBox.set(8); // warning: unchecked invocation to set(T)

警告显示原始类型绕过泛型类型检查,将不安全代码的捕获延迟到运行时,因此,你应该避免使用原始类型。

类型消除部分提供了有关Java编译器如何使用原始类型的更多信息。

未经检查的错误消息

如前所述,在将遗留代码与泛型代码混合时,你可能会遇到类似于以下内容的警告消息:

Note: Example.java uses unchecked or unsafe operations.

Note: Recompile with -Xlint:unchecked for details.

在使用对原始类型进行操作的旧API时会发生这种情况,如以下示例所示:

public class WarningDemo {

public static void main(String[] args){

Box bi;

bi = createBox();

}

static Box createBox(){

return new Box();

}

}

术语“unchecked”表示编译器没有足够的类型信息来执行确保类型安全所必需的所有类型检查,默认情况下,“unchecked”警告被禁用,尽管编译器会提示,要查看所有“unchecked”警告,请使用-Xlint:unchecked重新编译。

使用-Xlint:unchecked重新编译上一个示例显示以下附加信息:

WarningDemo.java:4: warning: [unchecked] unchecked conversion

found : Box

required: Box

bi = createBox();

^

1 warning

要完全禁用使用-Xlint:-unchecked标志的未经检查的警告,@SuppressWarnings("unchecked")注解会抑制未经检查的警告,如果你不熟悉@SuppressWarnings语法,请参阅注解。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值