25

Suppose I have the following expression

String myString = getStringFromSomeExternalSource();
if (myString != null && myString.trim().length() != 0) {
...
}

Eclipse warns me that myString might be null in the second phrase of the boolean expression. However, I know some that some compilers will exit the boolean expression entirely if the first condition fails. Is this true with Java? Or is the order of evaluation not guaranteed?

4
  • Which compiler or tool are you using?
    – notnoop
    Commented Jan 8, 2010 at 15:45
  • Well, javac (the most common compiler) doesn't warn about nullness. If "Java warns me that myString might be null", most likely that's a buggy tool. There is no such thing as "java warns".
    – notnoop
    Commented Jan 8, 2010 at 15:48
  • That is valid, @notnoop. I'm using Eclipse. My language was sloppy.
    – daveslab
    Commented Jan 8, 2010 at 15:49
  • In Eclipse, I can only reproduce the warning with an || operation or with 'myString == null'. Are you sure that Eclipse warned against this code snippet?
    – notnoop
    Commented Jan 8, 2010 at 15:52

4 Answers 4

47

However, I know some that some compilers will exit the boolean expression entirely if the first condition fails. Is this true with Java?

Yes, that is known as Short-Circuit evaluation.Operators like && and || are operators that perform such operations.

Or is the order of evaluation not guaranteed?

No,the order of evaluation is guaranteed(from left to right)

8

Java should be evaluating your statements from left to right. It uses a mechanism known as short-circuit evaluation to prevent the second, third, and nth conditions from being tested if the first is false.

So, if your expression is myContainer != null && myContainer.Contains(myObject) and myContainer is null, the second condition, myContainer.Contains(myObject) will not be evaluated.

Edit: As someone else mentioned, Java in particular does have both short-circuit and non-short-circuit operators for boolean conditions. Using && will trigger short-circuit evaluation, and & will not.

1
  • 1
    Quoting: To prevent the second, third, and nth conditions from being tested if the first is false. Actually if the operator is || the compiler cannot conclude the overall value from the first alone if the first is false.
    – H2ONaCl
    Commented Feb 9, 2012 at 7:59
2

James and Ed are correct. If you come across a case in which you would like all expressions to be evaluated regardless of previous failed conditions, you can use the non-short-circuiting boolean operator &.

1

Yes, Java practices lazy evaluation of if statements in this way. if myString==null, the rest of the if statement will not be evaluated

Not the answer you're looking for? Browse other questions tagged or ask your own question.