Class ModuleReference

public abstract class ModuleReference
extends Object

A reference to a module's content.

A module reference is a concrete implementation of this class that implements the abstract methods defined by this class. It contains the module's descriptor and its location, if known. It also has the ability to create a ModuleReader in order to access the module's content, which may be inside the Java run-time system itself or in an artifact such as a modular JAR file.

Since:
9
See Also:
ModuleFinder, ModuleReader

Constructors

Modifier Constructor Description
protected ModuleReference​(ModuleDescriptor descriptor, URI location)

Constructs a new instance of this class.

Methods

Modifier and Type Method Description
ModuleDescriptor descriptor()

Returns the module descriptor.

Optional<URI> location()

Returns the location of this module's content, if known.

abstract ModuleReader open()

Opens the module content for reading.

Methods declared in class java.lang.Object

clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

Constructors

ModuleReference

protected ModuleReference(ModuleDescriptor descriptor,
                          URI location)

Constructs a new instance of this class.

Parameters:
descriptor - The module descriptor
location - The module location or null if not known

Methods

descriptor

public final ModuleDescriptor descriptor()

Returns the module descriptor.

Returns:
The module descriptor

location

public final Optional<URI> location()

Returns the location of this module's content, if known.

This URI, when present, can be used as the location value of a CodeSource so that a module's classes can be granted specific permissions when loaded by a SecureClassLoader.

Returns:
The location or an empty Optional if not known

open

public abstract ModuleReader open()
                           throws IOException

Opens the module content for reading.

Returns:
A ModuleReader to read the module
Throws:
IOException - If an I/O error occurs
SecurityException - If denied by the security manager

© 1993, 2020, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/lang/module/ModuleReference.html