There is an operator ? :
in Java which can be used to select a value according to the boolean expression. For example, the expression 3 > 2 ? "true" : false
will return a string "true"
. I know we can use if
expression to do this, but I will prefer this style because it is concise and elegant.
相关问题
- Delete Messages from a Topic in Apache Kafka
- Jackson Deserialization not calling deserialize on
- How to maintain order of key-value in DataFrame sa
- StackExchange API - Deserialize Date in JSON Respo
- Difference between Types.INTEGER and Types.NULL in
In Java, there is a difference between
if
and? :
and that is thatif
is a statement while? :
is an expression. In Scala,if
is also an expression: it returns a value that you can for example assign to a variable.The
if
in Scala is much more like? :
in Java than theif
in Java:You cannot do this in Java:
So, it is really not necessary to have
? :
in Scala because it would be exactly the same asif
, but with alternative (more obscure) syntax.To add to what @Jesper said, if you find
if
-else
too verbose, Scalaz provides two more terser alternatives: A ternary boolean operator (?
,|
) a la C-like languages, andfold
function.In approximate order of importance:
1) The
:
symbol is reserved for type annotation2) In Scala, symbols can be used as identifiers for method and value names. There are only a limited number of these available on a standard keyboard, so if you decide to make two of these into keywords, you're reducing the pool of operators that can be used (see footnote for why they'd have to be keywords)
3) As Jesper says, the more powerful
if
/else
already fulfil this role, so the gain is marginal4) Scala also has pattern matching which fulfils a similar role with the
match
keyword, in a much more general way. E.g. what if your expression evaluates to a something that is not a boolean?5) It would add additional compiler complexity. Scala prefers simplicity and uniformity to special cases
6) It's a hangover from C, and is really quite an odd syntax. Scala has enough odd-looking syntax
Footnote: While it's possible to come up with a reasonable scheme to emulate
? :
as methods (see Ternary operator typing), it's not as viable as keywords. It is complex to handle typing properly when the "true" and "false" alternatives are of different numberic types, operator precedence is a problem since you need operators that are lower priority than anything else (or else you have to use parentheses), and performance will likely suffer due to the runtime nature of the implementation.