Domanda

The following code gives me a 'Dead Code' warning in 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);
    }

The warning appears at the line that says root = e;.

I looked up dead code and found that it is code hat has no effect and will therefore be ignored by the java compiler.

However, this root is a private field in my class and therefore it is necessary for the function of my program that I do this.

Is the compiler really going to ignore this? How can I stop that? Why does it think it is dead code?

È stato utile?

Soluzione

If root is a private field in your class that contains the add method you posted, then, as you said, the line root = e; should not be considered dead code by the Eclipse IDE.

The compiler should work fine ... it's just an IDE warning.

My guess would be that Eclipse does some sort of code walking (similar to Cyclomatic complexity tools) to determine code paths and find "dead code" and "unreachable code".

I would try refreshing, then doing a clean and build in the IDE. If that doesn't resolve it, Eclipse may just have a "false positive" on warning on dead code. Wouldn't be the first time ... I use both Eclipse and IntelliJ IDEA and have seen both IDEs incorrectly warn on code before. However, my code still compiles fine despite the IDE warning.

Altri suggerimenti

There are possibly two issues going on: first: The issue is that the line root is not "used" for anything. In findbugs the same error is referred to as a "dead store" which, per findbugs means:

This instruction assigns a value to a local variable, but the value is not read or used in any subsequent instruction. Often, this indicates an error, because the value computed is never used.

note that the keyword here is "Often".

I would check and make sure that root is being used as you expect, and if it is it could be, as mentioned by Philip Tenn, a false positive.

Second: Your issue may be related to this issue.

Since the source is not sufficient to find the exact cause I guess its related to the issues in eclipse related to Dead code. Some of the issues you can check here and here.

Look at your if condition.

Node<E> e = new Node<E>(element);
if (n == null) {
    // dead code here
}

This code is dead because n == null will always be false. You have just created a new instance of Node<E> on the previous line (unconditionally). A new object will never be null.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top