Method may fail to close stream on exception
Posted
by 01
on Stack Overflow
See other posts from Stack Overflow
or by 01
Published on 2010-04-17T10:21:43Z
Indexed on
2010/04/17
10:23 UTC
Read the original article
Hit count: 551
I get the critical error with finbugs
The method creates an IO stream object, does not assign it to any fields, pass it to other methods, or return it, and does not appear to close it on all possible exception paths out of the method. This may result in a file descriptor leak. It is generally a good idea to use a finally block to ensure that streams are closed.
try {
...
stdError = new BufferedReader(new InputStreamReader(p.getErrorStream()));
...
} catch (IOException e) {
throw new RuntimeException(e);
} finally {
try {
if (stdInput != null) {
stdInput.close();
}
if (stdError != null) {
stdError.close();
}
} catch (IOException e) {
throw new RuntimeException(e);
}
}
do i need to close also InputStreamReader or p.getErrorStream(it returns InputStream) ??
© Stack Overflow or respective owner