java – Eclipse中不需要的死代码警告

以下代码Eclipse中给出了一个“死代码”警告:
private void add(Node<E> n,E element) {
        Node<E> e = new Node<E>(element);
        if (n == null)
            root = e;
        else if (n.compareto(e) > 0)
            if (n.hasLeft())
                add(n.getLeft(),element);
            else
                n.setLeft(e);
        else if (n.hasRight())
            add(n.getRight(),element);
        else
            n.setRight(e);
        balance(e);
    }

警告出现在root = e;的行上.

我查了死代码,发现代码帽没有效果,因此会被java编译器忽略.

但是,这个root是我班级中的私有字段,因此我的程序功能是必要的.

编译器真的会忽略这个吗?我怎么能阻止它?为什么它认为它是死代码

解决方法

如果root是你的类中包含你发布的add方法的私有字段,那么,如你所说,行root = e;不应该被Eclipse IDE视为死代码.

编译器应该工作正常……它只是一个IDE警告.

我的猜测是Eclipse会执行某种代码行走(类似于Cyclomatic复杂性工具)来确定代码路径并找到“死代码”和“无法访问的代码”.

我会尝试刷新,然后干净并在IDE中构建.如果这不能解决它,Eclipse可能会对死代码发出警告“误报”.这不是第一次……我同时使用Eclipse和IntelliJ IDEA,并且看到两个IDE之前都错误地警告过代码.但是,尽管有IDE警告,我的代码仍可正常编译.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...