Top Description Inners Constructors Methods
java.nio.file

public final Class FileSystems

extends Object
Class Inheritance
Imports
java.nio.file.spi.FileSystemProvider, java.net.URI, java.io.IOException, java.security.AccessController, .PrivilegedAction, java.lang.reflect.Constructor, java.util.Collections, .Map, .ServiceConfigurationError, .ServiceLoader, jdk.internal.misc.VM, sun.nio.fs.DefaultFileSystemProvider

Factory methods for file systems. This class defines the getDefault method to get the default file system and factory methods to construct other types of file systems.

The first invocation of any of the methods defined by this class causes the default provider to be loaded. The default provider, identified by the URI scheme "file", creates the FileSystem that provides access to the file systems accessible to the Java virtual machine. If the process of loading or initializing the default provider fails then an unspecified error is thrown.

The first invocation of the installedProviders method, by way of invoking any of the newFileSystem methods defined by this class, locates and loads all installed file system providers. Installed providers are loaded using the service-provider loading facility defined by the ServiceLoader class. Installed providers are loaded using the system class loader. If the system class loader cannot be found then the platform class loader is used. Providers are typically installed by placing them in a JAR file on the application class path, the JAR file contains a provider-configuration file named java.nio.file.spi.FileSystemProvider in the resource directory META-INF/services, and the file lists one or more fully-qualified names of concrete subclass of FileSystemProvider that have a zero argument constructor. The ordering that installed providers are located is implementation specific. If a provider is instantiated and its getScheme returns the same URI scheme of a provider that was previously instantiated then the most recently instantiated duplicate is discarded. URI schemes are compared without regard to case. During construction a provider may safely access files associated with the default provider but care needs to be taken to avoid circular loading of other installed providers. If circular loading of installed providers is detected then an unspecified error is thrown.

This class also defines factory methods that allow a ClassLoader to be specified when locating a provider. As with installed providers, the provider classes are identified by placing the provider configuration file in the resource directory META-INF/services.

If a thread initiates the loading of the installed file system providers and another thread invokes a method that also attempts to load the providers then the method will block until the loading completes.

Since
1.7

Nested and Inner Type Summary

Modifier and TypeClass and Description
private static class

Constructor Summary

AccessConstructor and Description
private

Method Summary

Modifier and TypeMethod and Description
public static FileSystem

Returns:

the default file system
getDefault
()

Returns the default FileSystem.

public static FileSystem

Returns:

the reference to the file system
getFileSystem
(URI
the URI to locate the file system
uri
)

Returns a reference to an existing FileSystem.

public static FileSystem

Returns:

a new file system
newFileSystem
(URI
the URI identifying the file system
uri
,
Map<String, ?>
a map of provider specific properties to configure the file system; may be empty
env
)

Constructs a new file system that is identified by a URI

This method iterates over the installed providers to locate the provider that is identified by the URI scheme of the given URI.

public static FileSystem

Returns:

a new file system
newFileSystem
(URI
the URI identifying the file system
uri
,
Map<String, ?>
a map of provider specific properties to configure the file system; may be empty
env
,
ClassLoader
the class loader to locate the provider or null to only attempt to locate an installed provider
loader
)

Constructs a new file system that is identified by a URI

This method first attempts to locate an installed provider in exactly the same manner as the newFileSystem(URI,Map) method.

public static FileSystem

Returns:

a new file system
newFileSystem
(Path
the path to the file
path
,
ClassLoader
the class loader to locate the provider or null to only attempt to locate an installed provider
loader
)

Constructs a new FileSystem to access the contents of a file as a file system.

public static FileSystem

Returns:

a new file system
newFileSystem
(Path
the path to the file
path
,
Map<String, ?>
a map of provider specific properties to configure the file system; may be empty
env
)

Constructs a new FileSystem to access the contents of a file as a file system.

public static FileSystem

Returns:

a new file system
newFileSystem
(Path
the path to the file
path
)

Constructs a new FileSystem to access the contents of a file as a file system.

public static FileSystem

Returns:

a new file system
newFileSystem
(Path
the path to the file
path
,
Map<String, ?>
a map of provider specific properties to configure the file system; may be empty
env
,
ClassLoader
the class loader to locate the provider or null to only attempt to locate an installed provider
loader
)

Constructs a new FileSystem to access the contents of a file as a file system.

Inherited from java.lang.Object:
cloneequalsfinalizegetClasshashCodenotifynotifyAlltoStringwaitwaitwait

Constructor Detail

FileSystemsback to summary
private FileSystems()

Method Detail

getDefaultback to summary
public static FileSystem getDefault()

Returns the default FileSystem. The default file system creates objects that provide access to the file systems accessible to the Java virtual machine. The working directory of the file system is the current user directory, named by the system property user.dir. This allows for interoperability with the java.io.File class.

The first invocation of any of the methods defined by this class locates the default provider object. Where the system property java.nio.file.spi.DefaultFileSystemProvider is not defined then the default provider is a system-default provider that is invoked to create the default file system.

If the system property java.nio.file.spi.DefaultFileSystemProvider is defined then it is taken to be a list of one or more fully-qualified names of concrete provider classes identified by the URI scheme "file". Where the property is a list of more than one name then the names are separated by a comma. Each class is loaded, using the system class loader, and instantiated by invoking a one argument constructor whose formal parameter type is FileSystemProvider. The providers are loaded and instantiated in the order they are listed in the property. If this process fails or a provider's scheme is not equal to "file" then an unspecified error is thrown. URI schemes are normally compared without regard to case but for the default provider, the scheme is required to be "file". The first provider class is instantiated by invoking it with a reference to the system-default provider. The second provider class is instantiated by invoking it with a reference to the first provider instance. The third provider class is instantiated by invoking it with a reference to the second instance, and so on. The last provider to be instantiated becomes the default provider; its getFileSystem method is invoked with the URI "file:///" to get a reference to the default file system.

Subsequent invocations of this method return the file system that was returned by the first invocation.

Returns:FileSystem

the default file system

getFileSystemback to summary
public static FileSystem getFileSystem(URI uri)

Returns a reference to an existing FileSystem.

This method iterates over the installed providers to locate the provider that is identified by the URI scheme of the given URI. URI schemes are compared without regard to case. The exact form of the URI is highly provider dependent. If found, the provider's getFileSystem method is invoked to obtain a reference to the FileSystem.

Once a file system created by this provider is closed it is provider-dependent if this method returns a reference to the closed file system or throws FileSystemNotFoundException. If the provider allows a new file system to be created with the same URI as a file system it previously created then this method throws the exception if invoked after the file system is closed (and before a new instance is created by the newFileSystem method).

If a security manager is installed then a provider implementation may require to check a permission before returning a reference to an existing file system. In the case of the default file system, no permission check is required.

Parameters
uri:URI

the URI to locate the file system

Returns:FileSystem

the reference to the file system

Exceptions
IllegalArgumentException:
if the pre-conditions for the uri parameter are not met
FileSystemNotFoundException:
if the file system, identified by the URI, does not exist
ProviderNotFoundException:
if a provider supporting the URI scheme is not installed
SecurityException:
if a security manager is installed and it denies an unspecified permission
newFileSystemback to summary
public static FileSystem newFileSystem(URI uri, Map<String, ?> env) throws IOException

Constructs a new file system that is identified by a URI

This method iterates over the installed providers to locate the provider that is identified by the URI scheme of the given URI. URI schemes are compared without regard to case. The exact form of the URI is highly provider dependent. If found, the provider's newFileSystem(URI,Map) method is invoked to construct the new file system.

Once a file system is closed it is provider-dependent if the provider allows a new file system to be created with the same URI as a file system it previously created.

Usage Example: Suppose there is a provider identified by the scheme "memory" installed:

FileSystem fs = FileSystems.newFileSystem(URI.create("memory:///?name=logfs"), Map.of("capacity", "16G", "blockSize", "4k"));
FileSystem fs = FileSystems.newFileSystem(URI.create("memory:///?name=logfs"),
                                          Map.of("capacity", "16G", "blockSize", "4k"));
Parameters
uri:URI

the URI identifying the file system

env:Map<String, ?>

a map of provider specific properties to configure the file system; may be empty

Returns:FileSystem

a new file system

Exceptions
IOException:
if an I/O error occurs creating the file system
IllegalArgumentException:
if the pre-conditions for the uri parameter are not met, or the env parameter does not contain properties required by the provider, or a property value is invalid
FileSystemAlreadyExistsException:
if the file system has already been created
ProviderNotFoundException:
if a provider supporting the URI scheme is not installed
SecurityException:
if a security manager is installed and it denies an unspecified permission required by the file system provider implementation
newFileSystemback to summary
public static FileSystem newFileSystem(URI uri, Map<String, ?> env, ClassLoader loader) throws IOException

Constructs a new file system that is identified by a URI

This method first attempts to locate an installed provider in exactly the same manner as the newFileSystem(URI,Map) method. If none of the installed providers support the URI scheme then an attempt is made to locate the provider using the given class loader. If a provider supporting the URI scheme is located then its newFileSystem(URI,Map) is invoked to construct the new file system.

Parameters
uri:URI

the URI identifying the file system

env:Map<String, ?>

a map of provider specific properties to configure the file system; may be empty

loader:ClassLoader

the class loader to locate the provider or null to only attempt to locate an installed provider

Returns:FileSystem

a new file system

Exceptions
IOException:
an I/O error occurs creating the file system
IllegalArgumentException:
if the pre-conditions for the uri parameter are not met, or the env parameter does not contain properties required by the provider, or a property value is invalid
FileSystemAlreadyExistsException:
if the URI scheme identifies an installed provider and the file system has already been created
ProviderNotFoundException:
if a provider supporting the URI scheme is not found
ServiceConfigurationError:
when an error occurs while loading a service provider
SecurityException:
if a security manager is installed and it denies an unspecified permission required by the file system provider implementation
newFileSystemback to summary
public static FileSystem newFileSystem(Path path, ClassLoader loader) throws IOException

Constructs a new FileSystem to access the contents of a file as a file system.

This method makes use of specialized providers that create pseudo file systems where the contents of one or more files is treated as a file system.

This method first attempts to locate an installed provider in exactly the same manner as the newFileSystem(Path, Map, ClassLoader) method with an empty map. If none of the installed providers return a FileSystem then an attempt is made to locate the provider using the given class loader. If a provider returns a file system then the lookup terminates and the file system is returned.

Parameters
path:Path

the path to the file

loader:ClassLoader

the class loader to locate the provider or null to only attempt to locate an installed provider

Returns:FileSystem

a new file system

Exceptions
IOException:
if an I/O error occurs
ProviderNotFoundException:
if a provider supporting this file type cannot be located
ServiceConfigurationError:
when an error occurs while loading a service provider
SecurityException:
if a security manager is installed and it denies an unspecified permission
newFileSystemback to summary
public static FileSystem newFileSystem(Path path, Map<String, ?> env) throws IOException

Constructs a new FileSystem to access the contents of a file as a file system.

This method makes use of specialized providers that create pseudo file systems where the contents of one or more files is treated as a file system.

This method first attempts to locate an installed provider in exactly the same manner as the newFileSystem(Path, Map, ClassLoader) method. If found, the provider's newFileSystem(Path, Map) method is invoked to construct the new file system.

Parameters
path:Path

the path to the file

env:Map<String, ?>

a map of provider specific properties to configure the file system; may be empty

Returns:FileSystem

a new file system

Exceptions
IOException:
if an I/O error occurs
ProviderNotFoundException:
if a provider supporting this file type cannot be located
ServiceConfigurationError:
when an error occurs while loading a service provider
SecurityException:
if a security manager is installed and it denies an unspecified permission
Since
13
newFileSystemback to summary
public static FileSystem newFileSystem(Path path) throws IOException

Constructs a new FileSystem to access the contents of a file as a file system.

This method makes use of specialized providers that create pseudo file systems where the contents of one or more files is treated as a file system.

This method first attempts to locate an installed provider in exactly the same manner as the newFileSystem(Path, Map, ClassLoader) method. If found, the provider's newFileSystem(Path, Map) method is invoked with an empty map to construct the new file system.

Parameters
path:Path

the path to the file

Returns:FileSystem

a new file system

Exceptions
IOException:
if an I/O error occurs
ProviderNotFoundException:
if a provider supporting this file type cannot be located
ServiceConfigurationError:
when an error occurs while loading a service provider
SecurityException:
if a security manager is installed and it denies an unspecified permission
Since
13
newFileSystemback to summary
public static FileSystem newFileSystem(Path path, Map<String, ?> env, ClassLoader loader) throws IOException

Constructs a new FileSystem to access the contents of a file as a file system.

This method makes use of specialized providers that create pseudo file systems where the contents of one or more files is treated as a file system.

This method iterates over the installed providers. It invokes, in turn, each provider's newFileSystem(Path,Map) method. If a provider returns a file system then the iteration terminates and the file system is returned. If none of the installed providers return a FileSystem then an attempt is made to locate the provider using the given class loader. If a provider returns a file system, then the lookup terminates and the file system is returned.

Parameters
path:Path

the path to the file

env:Map<String, ?>

a map of provider specific properties to configure the file system; may be empty

loader:ClassLoader

the class loader to locate the provider or null to only attempt to locate an installed provider

Returns:FileSystem

a new file system

Exceptions
IOException:
if an I/O error occurs
ProviderNotFoundException:
if a provider supporting this file type cannot be located
ServiceConfigurationError:
when an error occurs while loading a service provider
SecurityException:
if a security manager is installed and it denies an unspecified permission
Since
13
java.nio.file back to summary

private Class FileSystems.DefaultFileSystemHolder

extends Object
Class Inheritance

Field Summary

Modifier and TypeField and Description
pack-priv static final FileSystem

Constructor Summary

AccessConstructor and Description
private

Method Summary

Modifier and TypeMethod and Description
private static FileSystem
private static FileSystemProvider
Inherited from java.lang.Object:
cloneequalsfinalizegetClasshashCodenotifynotifyAlltoStringwaitwaitwait

Field Detail

defaultFileSystemback to summary
pack-priv static final FileSystem defaultFileSystem

Constructor Detail

DefaultFileSystemHolderback to summary
private DefaultFileSystemHolder()

Method Detail

defaultFileSystemback to summary
private static FileSystem defaultFileSystem()
getDefaultProviderback to summary
private static FileSystemProvider getDefaultProvider()