I think you do for the (a==null) check, because there are two statements
against the failure condition (the assignment to b, and the second check).
if a is absent, then neither doSomethingIfBWasAbsent nor doSomethingWithB
should be called!

The second block can go though, and taking advantage of precedence for ==
gives:

final A a = getA();
a == null ? doSomethingIfAWasAbsent() : {
    final B b = getBFrom(a);
    b == null ? doSomethingIfBWasAbsent() :
doSomethingWithB(b);
};

Though my personal preference would be to retain the bracketing for the
equality checks, I find it easier to read that way. Past exposure to LISP
may have some influence on this though :)


On 27 July 2012 11:09, Ricky Clarkson <[email protected]> wrote:

> Kevin, I believe you don't need any of the (){} characters there, but
> maybe I'm missing something.
> On Jul 27, 2012 6:04 AM, "Kevin Wright" <[email protected]> wrote:
>
>> That's a bit open-ended, are you thinking of a particular construct that
>> you think would be challenging to convert?
>>
>> As another trivial example, something like this:
>>
>> final A a = getA();
>> if (a != null) {
>>     final B b = getBFrom(a);
>>     if (b != null) {
>>   doSomethingWithB(b);
>>   } else {
>>         doSomethingIfBWasAbsent();
>>     }
>> } else {
>>     doSomethingIfAWasAbsent();
>> }
>>
>>
>> Or with the tertiary operator:
>>
>> final A a = getA();
>> (a == null) ? doSomethingIfAWasAbsent() : {
>>     final B b = getBFrom(a);
>>     (b == null) ? doSomethingIfBWasAbsent() : {
>>    doSomethingWithB(b);
>> }
>> };
>>
>>
>> Could be written in Scala as:
>>
>> val a = getA
>> val b = a flatMap {getBFrom}
>> a getOrElse {doSomethingIfAWasAbsent()}
>> b getOrElse {doSomethingIfBWasAbsent()}
>> b forEach {doSomethingWithB}
>>
>>
>>
>>
>>
>> On 27 July 2012 04:16, Cédric Beust ♔ <[email protected]> wrote:
>>
>>> Yes but that's the most trivial case. For example, experiment with your
>>> Option code when the original code has else's.
>>>
>>> --
>>> Cédric
>>>
>>>
>>>
>>>
>>> On Thu, Jul 26, 2012 at 5:30 PM, clay <[email protected]> wrote:
>>>
>>>> Here is a simple example that illustrates the benefit of Option beyond
>>>> avoiding null exceptions:
>>>>
>>>> Here is a traditional piece of logic using traditional null if-checks.
>>>> This is using Scala syntax but would be equivalent in Java.
>>>>
>>>> val variableAMayBeNull: A = methodThatMayProduceA();
>>>> if (variableAMayBeNull != null) {
>>>> val variableBMayBeNull: B = tryToGetBFromA(variableAMayBeNull);
>>>>
>>>> if (variableBMayBeNull != null) {
>>>> doSomethingWithNonNullB(variableBMayBeNull);
>>>> }
>>>> }
>>>>
>>>> Same logic using Option. This is Scala syntax. Java can do this but not
>>>> as nicely until it gets lambdas.
>>>>
>>>> val variableAMayBeNull: Option[A] = methodThatMayProduceA();
>>>> val variableBMayBeNull: Option[B] =
>>>> variableAMayBeNull.flatMap(tryToGetBFromA);
>>>> variableBMayBeNull.foreach(doSomethingWithNonNullB);
>>>>
>>>> Both blocks are logically equivalent, but the Option route is much more
>>>> concise, elegant, and maintainable. The if-logic is moved from the end
>>>> application code to inside of the Option class. Since this type of logic is
>>>> so common in application code, the code simplification benefits are quite
>>>> large.
>>>>
>>>>
>>

-- 
You received this message because you are subscribed to the Google Groups "Java 
Posse" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to 
[email protected].
For more options, visit this group at 
http://groups.google.com/group/javaposse?hl=en.

Reply via email to