Class FileBackedOutputStream

java.lang.Object
java.io.OutputStream
com.google.common.io.FileBackedOutputStream
All Implemented Interfaces:
Closeable, Flushable, AutoCloseable

An OutputStream that starts buffering to a byte array, but switches to file buffering once the data reaches a configurable size.

When this stream creates a temporary file, it restricts the file's permissions to the current user or, in the case of Android, the current app. If that is not possible (as is the case under the very old Android Ice Cream Sandwich release), then this stream throws an exception instead of creating a file that would be more accessible. (This behavior is new in Guava 32.0.0. Previous versions would create a file that is more accessible, as discussed in Guava issue 2575. TODO: b/283778848 - Fill in CVE number once it's available.)

Temporary files created by this stream may live in the local filesystem until either:

  • reset() is called (removing the data in this stream and deleting the file), or...
  • this stream (or, more precisely, its asByteSource() view) is finalized during garbage collection, AND this stream was not constructed with the 1-arg constructor or the 2-arg constructor passing false in the second parameter.

This class is thread-safe.

Since:
1.0
Author:
Chris Nokleberg