gpt4 book ai didi

java - 不应使用来自 "com.sun.*"和 "sun.*"包的 SonarQube 规则类

转载 作者:塔克拉玛干 更新时间:2023-11-01 21:53:20 28 4
gpt4 key购买 nike

我有一个具有以下特征的 J2EE 项目:

CDI 1.0
Dynamic Web Module 3.0
Java 1.7 (it's being changed to 1.8)
JSF 2.0
JPA 2.0

我正在针对它运行 SonarQube 5.6.6 规则,感觉符合规则

不应使用“com.sun.”和“sun.”包中的类
鱿鱼:S1191

com.sun.* 和 sun.* 包中的类被视为实现细节,不是 Java API 的一部分。在迁移到新版本的 Java 时,它们可能会导致问题,因为没有向后兼容性保证。此类类几乎总是由应该改用的 Java API 类包装。

因为我正在使用类 com.sun.faces.application.ApplicationAssociatecom.sun.faces.application.ApplicationResourceBundle

我已经搜索了关于此的其他线程,其中大多数都说我应该更改规则以排除特定的包或类。

我认为简单地规避规则是没有意义的,所以我想知道这些 sun 类是否有实际的 java API(1.7 或 1.8)类。

如果没有,我认为最好保持警惕,直到 java API 类可用于这些 sun 类。

对此有什么提示/建议吗?

最佳答案

这是 SonarQube 中的一个错误。它过度概括了 sun.* 包,如 Why Developers Should Not Write Programs That Call 'sun' Packages 中所述。到 com.sun.* 包。这是不正确的。 Oracle 并没有在上面链接的文章中这么说。 SonarQube 实际上应该只惩罚 sun.* 包的使用或任意 JRE/JDK 实现内部使用的任何内容。 com.sun.* 包与 JRE/JDK API/impl 完全无关。

要么关闭 S1191 规则,要么将 com.sun.* 上的所有命中标记为误报。

另见:

关于java - 不应使用来自 "com.sun.*"和 "sun.*"包的 SonarQube 规则类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43869567/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com