Search code examples
javamultithreadingthread-safety

Is there a problem with several threads opening a stream on a resource and reading its content?


Code on a web server:

public byte[] loadData() {
    byte[] data = null;
    try(final InputStream resourceStream = getClass().getResourceAsStream("data.bin")) { 
        data = ByteStreams.toByteArray(resourceStream); //ByteStreams is from Guava library
    } catch (IOException e) {
        e.printStackTrace();
    }
    return data;
}

Is there a problem with several threads opening a stream on a resource and reading its content? In this case the resource is a data file contained in a jar.

On Windows, concurrently reading the resource was not a problem. However, this is not efficient, so I opted to use a WeakReference and double-checked locking to load the data only once.


Solution

  • The only state that may possibly be shared between your threads is the InputStream returned by getResourceAsStream(String). Let's check if it's the same object.

    Here's a very simple test you can use to try this out yourself:

    InputStream first = getClass().getResourceAsStream("data.bin")
    InputStream second = getClass().getResourceAsStream("data.bin")
    System.out.println(first == second);
    

    This will (typically) return false. Since they aren't the same object, you have no thread safety issues.


    I say typically because getResourceAsStream depends on the underlying ClassLoader that loaded the Class instance returned by getClass(). So, unless you're writing and using your own (or 3rd party) ClassLoader objects, you'll be fine.