Java导入类/枚举内部内部类时导入顺序的重要性

这是我的班级:

package pepelu;

import pepelu.ImportTest.InnerClass.InnerEnum;
import javax.annotation.Resource;

public class ImportTest {
    @Resource
    public static class InnerClass {
        public enum InnerEnum {
            A
        }
    }

    public static void main(String[] args) {
        System.out.println(InnerEnum.A);
    }
}

当我使用maven构建时,它会给出一个编译错误:

mvn clean compile

[ERROR] /Users/finup/Desktop/a/importtest/src/main/java/pepelu/ImportTest.java:[8,6] cannot find symbol

将导入订单更改为:

import javax.annotation.Resource;
import pepelu.ImportTest.InnerClass.InnerEnum;

我有一个成功的maven构建.

我搜索了文件,但无法找到解释.

有谁能解释一下导入在这种情况下是如何工作的?

解决方法:

我猜原因是一个“循环”依赖:你有一些元素X,你导入在你定义它的同一个文件/类中.

含义:

import pepelu.ImportTest.InnerClass.InnerEnum;

实际上是指同一个文件中的代码:

public static class InnerClass {
    public enum InnerEnum {

这意味着:对于编译器,为了处理该导入,它必须在同一文件中查看该类的主体.

似乎javac“立即”做到了.含义:它开始读取import语句,从同一个类导入使其“挂起”查看导入,但检查以下类定义.

并猜测:该类定义使用了另一个导入.为了“处理”该枚举的定义,编译器需要了解@Resource注释的位置/内容.但它还不知道注释(因为编译器还没有看到导入).

更改顺序时,编译器会理解类定义中的@Resource用法.

当然:真正的答案不是重新订购进口产品.真正的答案是不要从import语句后面的类中导入一些东西.这样做绝对没有意义.

编辑,鉴于OP关于如何在Redisson中发挥作用的评论:老实说,我不知道.它可能取决于该类的编译方式.也许这样的代码适用于较新(或较旧)的javac版本,也许这适用于eclipse或intellij或xyz编译器的特定版本.

含义:我给你解释了为什么你遇到这个问题.这并不意味着任何编译器都必须遇到同样的问题.

上一篇:java – 使用elasticache的日志中的DNS错误


下一篇:分布式锁(1)Redisson之RedissonLock