experience trying out lambda-8-b74
Peter Levart
peter.levart at gmail.com
Fri Feb 1 21:38:17 PST 2013
On 02/02/2013 12:44 AM, Henry Jen wrote:
> On 01/28/2013 12:16 AM, Peter Levart wrote:
>> On 01/28/2013 12:06 AM, Henry Jen wrote:
>>> http://cr.openjdk.java.net/~henryjen/lambda/nio.5/webrev/
>>>
>> Hi Henry,
>>
>> I can imagine that many times a single block of code would be
>> responsible for constructing a Path stream (possibly enclosed into a
>> try-with-resources construct) and consuming it's results, so having to
>> deal with the duality of IOException/UncheckedIOException is a
>> complication for a user in my opinion. Wouldn't it be better also for
>> the stream-factory methods to throw UncheckedIOException and for
>> CloseableStream.close() to also throw UncheckedIOException (that means,
>> only inheriting from AutoCloseable, not Closeable and co-variant-ly
>> redefining the throws declaration):
>>
>> public interface CloseableStream<T> extends Stream<T>, AutoCloseable {
>> @Override
>> void close() throws UncheckedIOException;
>> }
>>
> Hi Peter,
Hi Henry,
> Sorry for the late reply, I want to let the idea sink a little bit.
>
> After couple days, I am slightly prefer not to change it because,
>
> 1) The CloseableStream-factory method throws IOException reminds use of
> try-with-resource better than an unchecked exception.
The *Closeable*Stream method return type name also reminds of that ;-)
> 2) As factory methods throwing IOException, developer is dealing with
> duality already.
He is dealing with duality already *if* the factory methods are throwing
IOException. If they are throwing UncheckedIOException, he is not
dealing with duality.
> 3) If the close method throws UncheckedIOException as the stream
> handling, the suppressing of exceptions will be more confusing. Should
> developer look into cause IOException or the UncheckedIOException?
Do you think a programmer might want to handle different subtypes of
IOException differently? If that is the case, the javadoc should
document all the possible situations. And what about different subtypes
of IOException wrapped by UncheckedIOException while consuming the
stream? If the programmer already bothers to unwrap the unchecked
exception to do the cause analisys, then this same handler would be good
also for dealing with exceptions thrown in factory methods and
CloseableStream.close(). The streams API is a higher-lever wrapper over
the java.nio.file.DirectoryStream API and it is already wrapping the
lower-level IOException with UncheckedIOException when consuming the
CloseableStream. I think it should do it consistently. By doing it
consistently, it simplifies correct exception handling logic in *all*
situations.
> 4) When the implementation is a Closeable, the wrapping of IOException
> into an UncheckedIOException doesn't do any good except overhead in case
> developer want to deal with it. On the other hand, a IOException handler
> is probably in place as the factory methods throws IOException.
It is probably in place *if* the factory methods are throwing
IOException. If they are throwing UncheckedIOException, then such
handler is not there. The question is whether the UncheckedIOException
handler is in place too. If I look in one of your tests:
148 public void testWalk() {
149 try(CloseableStream<Path> s = Files.walk(testFolder)) {
150 Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
151 assertEquals(actual, all);
152 } catch (IOException ioe) {
153 fail("Unexpected IOException");
154 }
155 }
You haven't bothered to handle the UncheckedIOException (because the
test would fail anyway if it was thrown). But I'm afraid that average
programmer will walk away from similar codes with false sense of
confidence that he handled all exceptional situations when he put the
checked exception handler in place. I think that being consistent and
throwing UncheckedIOException everywhere would actually have greater
probability for average programmer to not miss the handling of
exceptional situations while consuming the stream - at least all
exceptional situations would be handled or not handled equally.
Regards, Peter
> Does it make sense?
>
> I updated the webrev to have some test coverage for exception handling,
> it's painful as always, but the duality is not what bothers me.
>
> http://cr.openjdk.java.net/~henryjen/lambda/nio.6/webrev/
>
> Cheers,
> Henry
>
More information about the lambda-dev
mailing list