trying out the prototype
Joe Darcy
joe.darcy at oracle.com
Wed Aug 25 10:08:17 PDT 2010
Gernot Neppert wrote:
> 2010/8/24 Joe Darcy <joe.darcy at oracle.com>:
>
>> With N resources, there are possibly N+1 exceptions that can come out of the
>> try-with-resources statement, 1 from the block itself and 1 from each of the
>> close calls. Only one of those exceptions can be the one which gets
>> propagated out of the block.
>>
>> As covered in the other recent thread, the first exception thrown is
>> estimated to be the most informative one about what actually went wrong.
>>
>> -Joe
>>
>>
>
>
> What I do understand is that the exception thrown from the block is
> considered more important than the exception thrown by the same
> resource afterwards, when it is being closed.
>
> I just doubt that you can make a similarily educated guess about the
> relative importance of exceptions thrown by unrelated resources.
> Here is a simple example:
>
> try(Writer out = new FileWriter("output.txt"; Reader in = new
> FileReader("input.txt"))
> {
> // Code to copy from in to out.
> }
>
> Now, if the constructor of 'in' throws a (relatively harmless)
> FileNotFoundException, the much more serious DiskFullException thrown
> by the close() method of 'out' will be lost.
>
It is trivial to generate situations where any fixed policy of
suppressing exceptions gives the "wrong" answer about propagating the
most informative exception.
The coin-dev list has hosted longs threads speculating how
try-with-resources would and would not work in practice.
We don't have to limit ourselves to speculating anymore: since there is
a prototype which can be easily downloaded and run on many platforms,
people can *use the feature* and report back how it works (or not) *in
practice*.
-Joe
More information about the coin-dev
mailing list