Primitive streams and optional
Tim Peierls
tim at peierls.net
Wed Dec 5 07:22:58 PST 2012
Agree with Brian on all points below.
On Wed, Dec 5, 2012 at 10:02 AM, Brian Goetz <brian.goetz at oracle.com> wrote:
> 3. Tolerate nulls. This treat nulls as "just another value" and
>>>>>>>
>>>>>>
> I think there may be some confusion due to the way the word "tolerance"
> has morphed in recent years? By "tolerate", we don't mean "all men hug and
> sing a song of unity", we mean "let's not have open violence in the
> streets." Perhaps we should call this "barely tolerate." As Doug said,
> the key casualty of this is modular reasoning about what will happen in
> various cases when there are nulls. I view this as an acceptable cost, and
> one borne entirely by the null-lovers. When we achieve a better world in
> which people don't put nulls in collections, it will become a purely
> theoretical concern.
>
>
> hopes that
>>>>>>> lambdas and downstream stages can deal.
>>>>>>>
>>>>>>
> The key is "hope". We don't guarantee that all stages *can* deal, nor do
> we bend over backwards to accommodate.
>
> For example, the semantics of findAny/First are (as currently written)
> pretty much incompatible with null-bearing streams. The return type is
> Optional<T> where Optional can either represent the absence of value or a
> present non-null value. So I think it is perfectly reasonble to say "if
> the stream contains nulls, this may throw NPE."
>
>
> As exemplified by the continuing set of patches for the
>> continuing (and probably never-ending) list of cases noted
>> on recent lambda-dev posts.
>>
>
> For many of these, I'm perfectly willing to specify that behavior in the
> presence of nulls is simply unpredictable; we're not necessarily patching
> things because we think they're bugs, so much as we're still at the point
> where patching is very cheap.
>
> "Using null here may void your warranty".
>
>
More information about the lambda-libs-spec-observers
mailing list