8185092: Data race in FilterOutputStream.close
Change boolean instance variable "closed" to an AtomicBoolean. Reviewed-by: martin, alanb, redestad
This commit is contained in:
parent
ae5e7de919
commit
d5769843a5
@ -50,7 +50,12 @@ public class FilterOutputStream extends OutputStream {
|
||||
/**
|
||||
* Whether the stream is closed; implicitly initialized to false.
|
||||
*/
|
||||
private boolean closed;
|
||||
private volatile boolean closed;
|
||||
|
||||
/**
|
||||
* Object used to prevent a race on the 'closed' instance variable.
|
||||
*/
|
||||
private final Object closeLock = new Object();
|
||||
|
||||
/**
|
||||
* Creates an output stream filter built on top of the specified
|
||||
@ -162,10 +167,15 @@ public class FilterOutputStream extends OutputStream {
|
||||
*/
|
||||
@Override
|
||||
public void close() throws IOException {
|
||||
if (closed) {
|
||||
return;
|
||||
}
|
||||
synchronized (closeLock) {
|
||||
if (closed) {
|
||||
return;
|
||||
}
|
||||
closed = true;
|
||||
}
|
||||
|
||||
Throwable flushException = null;
|
||||
try {
|
||||
|
Loading…
Reference in New Issue
Block a user