开发者

Java assert nasty side-effect - compiler bug?

开发者 https://www.devze.com 2022-12-20 21:54 出处:网络
This public class test { public static void main(String[] args) { Object o = null; assert o != null; if(o != null)

This

public class test 
{
    public static void main(String[] args) 
    {
        Object o = null;
        assert o != null;
        if(o != null)
          System.out.println("o != null");
    }
}

p开发者_如何转开发rints out "o != null"; both 1.5_22 and 1.6_18. Compiler bug? Commenting out the assert fixes it. The byte code appears to jump directly to the print statement when assertions are disabled:

 public static main(String[]) : void
   L0
    LINENUMBER 5 L0
    ACONST_NULL
    ASTORE 1
   L1
    LINENUMBER 6 L1
    GETSTATIC test.$assertionsDisabled : boolean
    IFNE L2
    ALOAD 1: o
    IFNONNULL L2
    NEW AssertionError
    DUP
    INVOKESPECIAL AssertionError.<init>() : void
    ATHROW
   L2
    LINENUMBER 8 L2
    GETSTATIC System.out : PrintStream
    LDC "o != null"
    INVOKEVIRTUAL PrintStream.println(String) : void
   L3
    LINENUMBER 9 L3
    RETURN
   L4


I don't know about "nasty". Can you give a real example of some code where this would bite you? Your example looks very contrived.

EDIT - out of curiosity, I typed in the program, compiled it and ran it with java 1.6.0_16. No compiler bug is evident for me:

  • With assertions enabled (java -ea test) I get an assertion error.
  • With assertions disabled (java test) I get no output.


Assertions can be enabled and disabled at runtime. If you execute your code with the -ea-switch (for enable assertions) the assert should work:

java -ea my.class


The JVM is optimising the if (o != null) clause away because you've already asserted that o is never going to be null.

Assertion are not enabled by default at runtime, and are generally used to validate that code fulfils some contract, e.g. you just want to make sure that a certain object is never going to be null (e.g. to avoid null pointer exceptions). It is because of that "contract" that the compiler can optimise the if (o != null) away, because it knows that this condition will never happen.

As they are generally not enabled at runtime, think of them as helping to develop a piece of code rather than a runtime error checking mechanism.

0

精彩评论

暂无评论...
验证码 换一张
取 消