In certain computer programming languages, the Elvis operator, often written
||, is a binary operator that returns its first operand if that operand is considered true, and otherwise evaluates and returns its second operand. Note that the first operand does not need to have the literal boolean value
true for the first operand to be returned; it just needs to be a value that is considered true by the specific language (such as
"hello" being considered true in C). The Elvis operator is a variant of the ternary conditional operator,
? : in the sense that the expression with the Elvis operator
A ?: B is approximately equivalent to the expression with the ternary operator
A ? A : B.
Some computer programming languages[which?] have different semantics for this operator: Instead of the first operand having to result in a boolean, it must result in an object reference. If the resulting object reference is not null, it is returned. Otherwise the value of the second operand (which may also be null) is returned.
In a language that supports the Elvis operator, something like this:
x = f() ?: g()
x equal to the result of
f() if that result is a true value, and to the result of
It is equivalent to this example, using the conditional ternary operator:
x = f() ? f() : g()
except that it does not evaluate the
f() twice if it is true.
Object reference variant
This code will result in a reference to an object that is guaranteed to not be null. Function
f() returns an object reference instead of a boolean, and may return null:
x = f() ?: "default value"
Languages supporting the Elvis operator
- In GNU C and C++ (that is: in C and C++ with GCC extensions), the second operand of the ternary operator is optional. This has been the case since at least GCC 2.95.3 (March 2001).
- In Apache Groovy, the "Elvis operator"
?:is documented as a distinct operator; this feature was added in Groovy 1.5 (December 2007). Groovy, unlike GNU C and PHP, does not simply allow the second operand of ternary
?:to be omitted; rather, binary
?:must be written as a single operator, with no whitespace in between.
- In PHP, the second operand of the ternary operator has been optional since PHP 5.3 (June 2009).
- The Fantom programming language has the
?:binary operator that compares its first operand with
- In Kotlin, the Elvis operator returns its left-hand side if it's not null, and its right-hand side otherwise. A common pattern is to use it with
return, like this:
val foo = bar() ?: return
- In Gosu, the
?:operator also returns the right operand if the left is null.
- In C#, the null-conditional operator,
?.is referred to as the "Elvis operator", but it does not perform the same function. Instead, the null-coalescing operator
- In ColdFusion and CFML, the Elvis operator was introduced using the
- The Xtend programming language has an Elvis operator.
- In Google's Closure Templates, the Elvis operator is a null coalescing operator, equivalent to
isNonnull($a) ? $a : $b.
- Swift supports this concept with its Nil-coalescing operator
(a ?? b).
- SQL supports this concept with its COALESCE function, e.g.
Analogous use of the short-circuiting OR operator
or) has the same behavior as the above: returning its first operand if it would evaluate to true in a boolean environment, and otherwise evaluating and returning its second operand. When the left hand side is true, the right hand side is not even evaluated; it is "short-circuited."
?:or conditional operator, when used as a ternary operator
- Null coalescing operator,
- Safe navigation operator, often
- Spaceship operator
- Option type
- Joyce Farrell. Java Programming. p. 276. ISBN 978-1285081953.
The new operator is called Elvis operator because it uses a question mark and a colon together (?:); if you view it sideways, it reminds you of Elvis Presley.
- "Using the GNU Compiler Collection (GCC): Conditionals". gcc.gnu.org.
- "Using and Porting the GNU Compiler Collection (GCC): C Extensions". gcc.gnu.org.
- "Elvis Operator (?: )".
- "The Apache Groovy programming language - Groovy 1.5 release notes". groovy-lang.org.
- "PHP: Comparison Operators - Manual". PHP website. Retrieved 2014-02-17.
- "Null Safety - Kotlin Programming Language". Kotlin.
- Albahari, Joseph; Albahari, Ben (2015). C# 6.0 in a Nutshell (6 ed.). O'Reilly Media. p. 59. ISBN 978-1491927069.
- Efftinge, Sven. "Xtend - Expressions". eclipse.org.
- "Closure Template Concepts - Closure Templates". Google Developers.
- "The Swift Programming Language (Swift 4.1): Basic Operators". developer.apple.com.