Fix a potential fd leak in AbstractDiskHttpData.getChunk (#10270)
Motivation: `FileChannel.read()` may throw an IOException. We must deal with this in case of the occurrence of `I/O` error. Modification: Place the `FileChannel.read()` method call in the `try-finally` block. Result: Advoid fd leak. Co-authored-by: Norman Maurer <norman_maurer@apple.com>
This commit is contained in:
parent
32f2b9c805
commit
e7c5773162
@ -295,15 +295,17 @@ public abstract class AbstractDiskHttpData extends AbstractHttpData {
|
|||||||
}
|
}
|
||||||
int read = 0;
|
int read = 0;
|
||||||
ByteBuffer byteBuffer = ByteBuffer.allocate(length);
|
ByteBuffer byteBuffer = ByteBuffer.allocate(length);
|
||||||
|
try {
|
||||||
while (read < length) {
|
while (read < length) {
|
||||||
int readnow = fileChannel.read(byteBuffer);
|
int readnow = fileChannel.read(byteBuffer);
|
||||||
if (readnow == -1) {
|
if (readnow == -1) {
|
||||||
fileChannel.close();
|
|
||||||
fileChannel = null;
|
|
||||||
break;
|
break;
|
||||||
} else {
|
}
|
||||||
read += readnow;
|
read += readnow;
|
||||||
}
|
}
|
||||||
|
} finally {
|
||||||
|
fileChannel.close();
|
||||||
|
fileChannel = null;
|
||||||
}
|
}
|
||||||
if (read == 0) {
|
if (read == 0) {
|
||||||
return EMPTY_BUFFER;
|
return EMPTY_BUFFER;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user