118.md 3.2 KB
Newer Older
W
init  
wizardforcel 已提交
1 2 3 4
# 原始类型

> 原文: [https://docs.oracle.com/javase/tutorial/java/generics/rawTypes.html](https://docs.oracle.com/javase/tutorial/java/generics/rawTypes.html)

W
wizardforcel 已提交
5
*原始类型*是没有任何类型参数的泛型类或接口的名称。例如,给定通用`Box`类:
W
init  
wizardforcel 已提交
6

W
wizardforcel 已提交
7
```java
W
init  
wizardforcel 已提交
8 9 10 11 12 13 14
public class Box<T> {
    public void set(T t) { /* ... */ }
    // ...
}

```

W
wizardforcel 已提交
15
创建参数化类型的`Box&lt; T>` ,为正式类型参数`T`提供实际类型参数:
W
init  
wizardforcel 已提交
16

W
wizardforcel 已提交
17
```java
W
init  
wizardforcel 已提交
18 19 20 21
Box<Integer> intBox = new Box<>();

```

W
wizardforcel 已提交
22
如果省略实际类型参数,则创建`Box&lt; T&gt;的原始类型。`
W
init  
wizardforcel 已提交
23

W
wizardforcel 已提交
24
```java
W
init  
wizardforcel 已提交
25 26 27 28
Box rawBox = new Box();

```

W
wizardforcel 已提交
29
因此, `Box`是泛型类型`Box&lt; T&gt;的原始类型。` 。但是,非泛型类或接口类型是*而不是*原始类型。
W
init  
wizardforcel 已提交
30

W
wizardforcel 已提交
31
原始类型显示在遗留代码中,因为许多 API 类(例如`集合`类)在 JDK 5.0 之前不是通用的。当使用原始类型时,你基本上得到了前仿制行为 - `Box`给你`对象`。为了向后兼容,允许将参数化类型分配给其原始类型:
W
init  
wizardforcel 已提交
32

W
wizardforcel 已提交
33
```java
W
init  
wizardforcel 已提交
34 35 36 37 38 39 40
Box<String> stringBox = new Box<>();
Box rawBox = stringBox;               // OK

```

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

W
wizardforcel 已提交
41
```java
W
init  
wizardforcel 已提交
42 43 44 45 46 47 48
Box rawBox = new Box();           // rawBox is a raw type of Box<T>
Box<Integer> intBox = rawBox;     // warning: unchecked conversion

```

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

W
wizardforcel 已提交
49
```java
W
init  
wizardforcel 已提交
50 51 52 53 54 55 56 57 58 59 60 61 62 63
Box<String> stringBox = new Box<>();
Box rawBox = stringBox;
rawBox.set(8);  // warning: unchecked invocation to set(T)

```

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

[类型擦除](erasure.html)部分提供了有关 Java 编译器如何使用原始类型的更多信息。

## 未选中的错误消息

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

W
wizardforcel 已提交
64
```java
W
init  
wizardforcel 已提交
65 66 67 68 69 70 71
Note: Example.java uses unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.

```

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

W
wizardforcel 已提交
72
```java
W
init  
wizardforcel 已提交
73 74 75 76 77 78 79 80 81 82 83 84 85
public class WarningDemo {
    public static void main(String[] args){
        Box<Integer> bi;
        bi = createBox();
    }

    static Box createBox(){
        return new Box();
    }
}

```

W
wizardforcel 已提交
86
术语“未选中”表示编译器没有足够的类型信息来执行确保类型安全所必需的所有类型检查。默认情况下,“unchecked”警告被禁用,尽管编译器提供了提示。要查看所有“未选中”警告,请使用`-Xlint 重新编译:取消选中`
W
init  
wizardforcel 已提交
87

W
wizardforcel 已提交
88
`-Xlint 重新编译前面的例子:unchecked`显示以下附加信息:
W
init  
wizardforcel 已提交
89

W
wizardforcel 已提交
90
```java
W
init  
wizardforcel 已提交
91 92 93 94 95 96 97 98 99
WarningDemo.java:4: warning: [unchecked] unchecked conversion
found   : Box
required: Box<java.lang.Integer>
        bi = createBox();
                      ^
1 warning

```

W
wizardforcel 已提交
100
要完全禁用未检查的警告,请使用`-Xlint:-unchecked`标志。 `@SuppressWarnings(“未选中”)`注释会抑制未经检查的警告。如果您不熟悉`@SuppressWarnings`语法,请参阅[注释](../../java/annotations/index.html)