trying out the prototype

Gernot Neppert mcnepp02 at googlemail.com
Tue Aug 24 02:27:20 PDT 2010


Hello,

first of all I have to say that as a long-time advocate of some kind
of ARM in Java I'm thrilled to finally see it in action!

I've toyed with the latest snapshot and have 2 remarks:

1. If you initialize a Resource that can only throw on close(), you
get a compiler error that might be confusing because the automatic
invocation of close() is invisible to the person writing the code.
Here's a not-so-useful example that nevertheless exhibits the
aforementioned behaviour:

try (Reader rdr = new StringReader("Some text"))
{
}

2. If you use multiple Resources, an exception thrown by one of them
will suppress exceptions thrown by the 'close()' invocation of others.
While I can see some sense in suppressing exceptions from 'close()' of
the same instance, I cannot see why this reasoning should apply to
other instances.
(I guess this forms a case against the try-with-multiple-resources
statement in general. The list of semicolon-delimited declarations
enclosed by parentheses looks weird, anyway ;-)
Here's an example:

class ThrowsOnRead extends Reader
{
    public int read(char[] cbuf, int off, int len) throws IOException
   {
      throw new IOException();
   }

	@Override
	public void close() throws IOException
       {
		
       }
}

class ThrowsOnClose extends Reader
{
    public void close() throws IOException
   {
     throw new IOException();
   }

    public int read(char[] cbuf, int off, int len) throws IOException
   {
     return 0;
   }
}



public class TestAutoClose {

	public static void main(String[] args) throws IOException {
		try(Reader rdr1 = new ThrowsOnRead(); Reader rdr2 = new ThrowsOnClose())
		{
		    rdr1.read();  // Why is this exception more important than the
one thrown by rdr2.close() ?
		}
	}
}



More information about the coin-dev mailing list