当前位置: 首页 > 图灵资讯 > 技术篇> 原始类型和遗留代码

原始类型和遗留代码

来源:图灵教育
时间:2024-12-25 17:02:31

引入原始类型是为了实现遗留(前泛型)代码与jdk 5中引入的泛型之间的兼容性。它们可以实现逐步过渡,但会损害类型安全。

定义和特征 原始类型:

  • 使用泛型类而不指定类型参数。 例子:

gen raw = new gen(new double(98.6)); // tipo bruto criado

兼容性:

原始类型变量可以接收任何泛型对象,反之亦然。 没有编译时类型检查,可能导致运行时错误。

代码示例

// classe gen com suporte a genéricos
class gen<t> {
    t ob; // declara um objeto do tipo t

    gen(t o) { // construtor
        ob = o;
    }

    t getob() { // retorna o objeto ob
        return ob;
    }
}

// demonstração de tipos brutos
class rawdemo {
    public static void main(string[] args) {
        // usando genéricos corretamente
        gen<integer> iob = new gen<>(88);
        gen<string> strob = new gen<>("generics test");

        // criando um tipo bruto
        gen raw = new gen(new double(98.6));
        double d = (double) raw.getob(); // funciona, mas perde segurança de tipos
        system.out.println("value: " + d);

        // erros de tempo de execução com tipos brutos
        // int i = (integer) raw.getob(); // erro de tempo de execução!

        // atribuição de tipo bruto para genérico
        strob = raw; // correto, mas perigoso
        // string str = strob.getob(); // erro de tempo de execução!

        // atribuição de genérico para tipo bruto
        raw = iob; // correto, mas perigoso
        // d = (double) raw.getob(); // erro de tempo de execução!
    }
}

使用原始类型的风险缺乏类型安全:

  • 将原始类型分配给泛型或反之亦然可能会导致运行时错误。

示例:

strob = raw; // perigoso: raw contém double, mas strob espera string
raw = iob; // perigoso: raw agora contém integer, mas coerção pode falhar

运行时异常:

无法在编译时检测不一致的情况。 示例:

int i = (integer) raw.getob(); // erro porque raw contém double

未验证警告:

  • javac 编译器在检测到以不安全方式使用的原始类型时会生成警告。

生成警告的示例

gen raw = new gen(new double(98.6)); // tipo bruto
strob = raw; // atribuição insegura

推荐 避免使用原始类型:

  • 始终使用类型参数来利用泛型提供的安全性。

示例:

Gen<Integer> iOb = new Gen<>(88); // Correto e seguro

小心对待遗留代码:

  • 在将预泛型代码与泛型集成时添加严格的检查和测试。

以上就是原始类型和遗留代码的详细内容,更多请关注图灵教育其它相关文章!