首页 > Java > java教程 > 使用仿制药的限制

使用仿制药的限制

Barbara Streisand
发布: 2024-12-30 21:25:14
原创
423 人浏览过

Restrições ao Uso de Genéricos

Java 中的泛型提供了灵活性和安全性,但也有一些重要的限制。这些涉及类型参数、静态成员、泛型数组和泛型异常的实例化

1。类型参数的实例化

  • 您无法直接从类型参数创建实例。

无效示例:

class Gen<T> {
    T ob;

    Gen() {
        ob = new T(); // Inválido!
    }
}

登录后复制
  • 原因:编译器不知道实际类型 T 代表什么,因为它只是一个占位符。
  • 解决方法:使用对象工厂或将已创建的实例作为参数。

2。静态成员的限制
静态成员不能使用外部类的泛型类型参数。

无效示例:

class Wrong<T> {
    static T ob;          // Inválido!
    static T getob() {    // Inválido!
        return ob;
    }
}

登录后复制

原因:静态上下文在类的所有实例之间共享,而泛型参数可能因实例而异。
解决方法: 声明定义自己类型参数的静态方法:

static <U> U genericMethod(U value) {
    return value;
}

登录后复制

3。通用数组
数组和泛型的约束:

  • 无法实例化泛型类型数组。
T vals[];        // Válido como referência
vals = new T[10]; // Inválido!

登录后复制
  • 无法创建特定于类型的通用引用数组
Gen<Integer> gens[] = new Gen<Integer>[10]; // Inválido!

登录后复制

原因:在执行过程中,擦除会消除类型信息,从而无法创建安全数组。
解决方法:

使用现有数组:

vals = nums; // Atribuir array existente é válido.

登录后复制
  • 使用通配符
Gen<?> gens[] = new Gen<?>[10]; // Correto.

登录后复制

4。通用异常
泛型类不能扩展 Throwable。
无效示例:

class GenException<T> extends Exception { // Inválido!
    T value;
}

登录后复制

原因:这可能会损害运行时的异常处理机制。
解决方案: 使用普通泛型类封装信息,然后与标准异常集成。

5。限制摘要
类型参数的实例化:不能直接实例化,但可以使用现有实例。
静态成员:不能使用外部类的泛型类型,但静态方法可以定义自己的泛型参数。
泛型数组:不能直接实例化,但允许使用通配符进行泛型引用。
通用异常:无法创建,但可以使用普通类进行模拟。

理解这些限制对于在 Java 中设计安全高效的泛型类至关重要。

以上是使用仿制药的限制的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板