Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Java boolean |= operator

Recently I saw a code using this:

boolean val = something();
val |= somethingElse();

Interesting part is |= (binary like) operator made on boolean primitive type.

It surprised me that |= exist for boolean, as if it was integer type, and searched Java specification for this operator, but could not find any.

I'd be curious if right operand is evaluated if left value already is true.

Can someone point me to Java specification of this?

like image 953
Pointer Null Avatar asked Mar 14 '13 13:03

Pointer Null


3 Answers

From the JLS:

15.26.2. Compound Assignment Operators

A compound assignment expression of the form E1 op= E2 is equivalent to E1 = (T) ((E1) op (E2)), where T is the type of E1, except that E1 is evaluated only once.

15.22.2. Boolean Logical Operators &, ^, and |

When both operands of a &, ^, or | operator are of type boolean or Boolean, then the type of the bitwise operator expression is boolean. In all cases, the operands are subject to unboxing conversion (§5.1.8) as necessary.

For |, the result value is false if both operand values are false; otherwise, the result is true.

This means that

val |= somethingElse();

is strictly equivalent to

val = val | somethingElse();

(assuming somethingElse() returns boolean or Boolean).

I'd be curious if right operand is evaluated if left value already is true.

Yes, it would be evaluated, since | does not short-circuit:

15.7.2. Evaluate Operands before Operation

The Java programming language guarantees that every operand of an operator (except the conditional operators &&, ||, and ? :) appears to be fully evaluated before any part of the operation itself is performed.

15.24. Conditional-Or Operator ||

Thus, || computes the same result as | on boolean or Boolean operands. It differs only in that the right-hand operand expression is evaluated conditionally rather than always.

like image 118
NPE Avatar answered Nov 14 '22 02:11

NPE


See http://docs.oracle.com/javase/specs/jls/se7/html/jls-15.html#jls-15.22.2 for the definition of |. See http://docs.oracle.com/javase/specs/jls/se7/html/jls-15.html#jls-15.26.2 for the defintion of |=. The definitions are just what you would think.

What surprises me is the lack of a ||= operator.

like image 35
Theodore Norvell Avatar answered Nov 14 '22 04:11

Theodore Norvell


The bitwise logic operators will have the same effect of "normal" logic operators on booleans.

From Java Language Specification 15.22:

When both operands of a &, ^, or | operator are of type boolean or Boolean, then the type of the bitwise operator expression is boolean. In all cases, the operands are subject to unboxing conversion (§5.1.8) as necessary.

For &, the result value is true if both operand values are true; otherwise, the result is false.

For ^, the result value is true if the operand values are different; otherwise, the result is false.

For |, the result value is false if both operand values are false; otherwise, the result is true.

The only real difference is that bitwise operators cant be used to short-circuit evaluation.

For example, this code will throw NullPointerException:

Boolean b1 = new Boolean(true);
Boolean b2 = null;
if (b1 || b2) {
    //no null pointer here;
}
if (b1 | b2) {
    //null pointer here;
}
like image 3
Jean Waghetti Avatar answered Nov 14 '22 03:11

Jean Waghetti