try-with-resources and null resource
Florian Weimer
fweimer at bfk.de
Fri Jan 28 01:30:46 PST 2011
* Reinier Zwitserloot:
> 2 if yes: Well, then, calling a method that returns null, such as for
> example Class.getResourceAsStream, is going to be an unbelievable pain. As
> the NPE is then unavoidable, you'd need to assign it to a variable, check
> that variable, and if that variable is not null, start a try block, which
> REQUIRES that you create a NEW variable. urghhhhh!!!!!!! What do I name
> this? out1 and out2? I've got a very big problem with this. even if t is not
> final, I'd have to create a dummy input stream just to have something to
> close.
If t is not referenced (so its declared type does not matter) and can
be null, use a utility method which returns a dummy AutoCloseable
instance if the passed argument is null.
If you reference t on some path, you need to generate a dynamic proxy
for the null case which throws some suitable exception on all method
calls except close(). It's ugly, but it's doable. I don't think it's
necessary to have direct support for such an edge case.
By the way, has anybody else seen this phenomenon in their code base?
InputStream in = null;
try {
in = new FileInputStream(path);
useFile(in);
} finally {
if (in != null) {
in.close();
}
}
I'm wondering where this is coming from.
--
Florian Weimer <fweimer at bfk.de>
BFK edv-consulting GmbH http://www.bfk.de/
Kriegsstraße 100 tel: +49-721-96201-1
D-76133 Karlsruhe fax: +49-721-96201-99
More information about the coin-dev
mailing list