ModuleReference (Java SE 10 & JDK 10 )
- java.lang.Object
-
- java.lang.module.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
ModuleReaderin 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
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedModuleReference(ModuleDescriptor descriptor, URI location)Constructs a new instance of this class.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description ModuleDescriptordescriptor()Returns the module descriptor.
Optional<URI>location()Returns the location of this module's content, if known.
abstract ModuleReaderopen()Opens the module content for reading.
-
-
-
Constructor Detail
-
ModuleReference
protected ModuleReference(ModuleDescriptor descriptor, URI location)
Constructs a new instance of this class.
- Parameters:
descriptor- The module descriptorlocation- The module location ornullif not known
-
-
Method Detail
-
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
CodeSourceso that a module's classes can be granted specific permissions when loaded by aSecureClassLoader.- Returns:
- The location or an empty
Optionalif not known
-
open
public abstract ModuleReader open() throws IOException
Opens the module content for reading.
- Returns:
- A
ModuleReaderto read the module - Throws:
IOException- If an I/O error occursSecurityException- If denied by the security manager
-
-
Report a bug or suggest an enhancement
For further API reference and developer documentation see the Java SE Documentation, which contains more detailed, developer-targeted descriptions with conceptual overviews, definitions of terms, workarounds, and working code examples.
Java is a trademark or registered trademark of Oracle and/or its affiliates in the US and other countries.
Copyright © 1993, 2018, Oracle and/or its affiliates, 500 Oracle Parkway, Redwood Shores, CA 94065 USA.
All rights reserved. Use is subject to license terms and the documentation redistribution policy.