8326126: Update the java manpage with the changes from JDK-8322478
Reviewed-by: alanb, cstein
This commit is contained in:
parent
20a25f60ea
commit
a3d7f9f242
@ -63,7 +63,7 @@ or
|
|||||||
\f[V]java\f[R] [\f[I]options\f[R]] \f[V]--module\f[R]
|
\f[V]java\f[R] [\f[I]options\f[R]] \f[V]--module\f[R]
|
||||||
\f[I]module\f[R][\f[V]/\f[R]\f[I]mainclass\f[R]] [\f[I]args\f[R] ...]
|
\f[I]module\f[R][\f[V]/\f[R]\f[I]mainclass\f[R]] [\f[I]args\f[R] ...]
|
||||||
.PP
|
.PP
|
||||||
To launch a single source-file program:
|
To launch a source-file program:
|
||||||
.PP
|
.PP
|
||||||
\f[V]java\f[R] [\f[I]options\f[R]] \f[I]source-file\f[R] [\f[I]args\f[R]
|
\f[V]java\f[R] [\f[I]options\f[R]] \f[I]source-file\f[R] [\f[I]args\f[R]
|
||||||
\&...]
|
\&...]
|
||||||
@ -100,11 +100,10 @@ See \f[B]Standard Options for Java\f[R].
|
|||||||
.RE
|
.RE
|
||||||
.TP
|
.TP
|
||||||
\f[I]source-file\f[R]
|
\f[I]source-file\f[R]
|
||||||
Only used to launch a single source-file program.
|
Only used to launch a source-file program.
|
||||||
Specifies the source file that contains the main class when using
|
Specifies the source file that contains the main class when using
|
||||||
source-file mode.
|
source-file mode.
|
||||||
See \f[B]Using Source-File Mode to Launch Single-File Source-Code
|
See \f[B]Using Source-File Mode to Launch Source-Code Programs\f[R]
|
||||||
Programs\f[R]
|
|
||||||
.TP
|
.TP
|
||||||
\f[I]args\f[R] ...
|
\f[I]args\f[R] ...
|
||||||
Optional: Arguments following \f[I]mainclass\f[R],
|
Optional: Arguments following \f[I]mainclass\f[R],
|
||||||
@ -128,8 +127,8 @@ The method declaration has the following form:
|
|||||||
.PP
|
.PP
|
||||||
In source-file mode, the \f[V]java\f[R] command can launch a class
|
In source-file mode, the \f[V]java\f[R] command can launch a class
|
||||||
declared in a source file.
|
declared in a source file.
|
||||||
See \f[B]Using Source-File Mode to Launch Single-File Source-Code
|
See \f[B]Using Source-File Mode to Launch Source-Code Programs\f[R] for
|
||||||
Programs\f[R] for a description of using the source-file mode.
|
a description of using the source-file mode.
|
||||||
.RS
|
.RS
|
||||||
.PP
|
.PP
|
||||||
\f[B]Note:\f[R] You can use the \f[V]JDK_JAVA_OPTIONS\f[R] launcher
|
\f[B]Note:\f[R] You can use the \f[V]JDK_JAVA_OPTIONS\f[R] launcher
|
||||||
@ -157,7 +156,7 @@ Use \f[V]javaw\f[R] when you don\[aq]t want a command prompt window to
|
|||||||
appear.
|
appear.
|
||||||
The \f[V]javaw\f[R] launcher will, however, display a dialog box with
|
The \f[V]javaw\f[R] launcher will, however, display a dialog box with
|
||||||
error information if a launch fails.
|
error information if a launch fails.
|
||||||
.SH USING SOURCE-FILE MODE TO LAUNCH SINGLE-FILE SOURCE-CODE PROGRAMS
|
.SH USING SOURCE-FILE MODE TO LAUNCH SOURCE-CODE PROGRAMS
|
||||||
.PP
|
.PP
|
||||||
To launch a class declared in a source file, run the \f[V]java\f[R]
|
To launch a class declared in a source file, run the \f[V]java\f[R]
|
||||||
launcher in source-file mode.
|
launcher in source-file mode.
|
||||||
@ -205,26 +204,25 @@ Any arguments placed after the name of the source file in the original
|
|||||||
command line are passed to the compiled class when it is executed.
|
command line are passed to the compiled class when it is executed.
|
||||||
.PP
|
.PP
|
||||||
For example, if a file were named \f[V]HelloWorld.java\f[R] and
|
For example, if a file were named \f[V]HelloWorld.java\f[R] and
|
||||||
contained a class named \f[V]hello.World\f[R], then the source-file mode
|
contained a class named \f[V]HelloWorld\f[R], then the source-file mode
|
||||||
command to launch the class would be:
|
command to launch the class would be:
|
||||||
.RS
|
.RS
|
||||||
.PP
|
.PP
|
||||||
\f[V]java HelloWorld.java\f[R]
|
\f[V]java HelloWorld.java\f[R]
|
||||||
.RE
|
.RE
|
||||||
.PP
|
.PP
|
||||||
The example illustrates that the class can be in a named package, and
|
|
||||||
does not need to be in the unnamed package.
|
|
||||||
This use of source-file mode is informally equivalent to using the
|
This use of source-file mode is informally equivalent to using the
|
||||||
following two commands where \f[V]hello.World\f[R] is the name of the
|
following two commands:
|
||||||
class in the package:
|
|
||||||
.IP
|
.IP
|
||||||
.nf
|
.nf
|
||||||
\f[CB]
|
\f[CB]
|
||||||
javac -d <memory> HelloWorld.java
|
javac -d <memory> --source-path <source-root> HelloWorld.java
|
||||||
java -cp <memory> hello.World
|
java --class-path <memory> HelloWorld
|
||||||
\f[R]
|
\f[R]
|
||||||
.fi
|
.fi
|
||||||
.PP
|
.PP
|
||||||
|
where \f[V]<source-root>\f[R] is computed
|
||||||
|
.PP
|
||||||
\f[B]In source-file mode, any additional command-line options are
|
\f[B]In source-file mode, any additional command-line options are
|
||||||
processed as follows:\f[R]
|
processed as follows:\f[R]
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
@ -253,9 +251,24 @@ filename with an \f[V]\[at]\f[R] character.
|
|||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
Any command-line options that are relevant to the compilation
|
Any command-line options that are relevant to the compilation
|
||||||
environment are taken into account.
|
environment are taken into account.
|
||||||
|
These include:
|
||||||
|
\f[V]--class-path\f[R]/\f[V]-classpath\f[R]/\f[V]-cp\f[R],
|
||||||
|
\f[V]--module-path\f[R]/\f[V]-p\f[R], \f[V]--add-exports\f[R],
|
||||||
|
\f[V]--add-modules\f[R], \f[V]--limit-modules\f[R],
|
||||||
|
\f[V]--patch-module\f[R], \f[V]--upgrade-module-path\f[R],
|
||||||
|
\f[V]--enable-preview\f[R].
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
No other source files are found and compiled, as if the source path is
|
The root of the source tree, \f[V]<source-root>\f[R] is computed from
|
||||||
set to an empty value.
|
the package of the class being launched.
|
||||||
|
For example, if \f[V]HelloWorld.java\f[R] declared its classes to be in
|
||||||
|
the \f[V]hello\f[R] package, then the file \f[V]HelloWorld.java\f[R] is
|
||||||
|
expected to reside in the directory \f[V]somedir/hello/\f[R].
|
||||||
|
In this case, \f[V]somedir\f[R] is computed to be the root of the source
|
||||||
|
tree.
|
||||||
|
.IP \[bu] 2
|
||||||
|
The root of the source tree serves as the source-path for compilation,
|
||||||
|
so that other source files found in that tree and are needed by
|
||||||
|
\f[V]HelloWorld\f[R] could be compiled.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
Annotation processing is disabled, as if \f[V]-proc:none\f[R] is in
|
Annotation processing is disabled, as if \f[V]-proc:none\f[R] is in
|
||||||
effect.
|
effect.
|
||||||
@ -266,45 +279,54 @@ the compilation.
|
|||||||
This sets both the source version accepted by compiler and the system
|
This sets both the source version accepted by compiler and the system
|
||||||
API that may be used by the code in the source file.
|
API that may be used by the code in the source file.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
The source file is compiled in the context of an unnamed module.
|
If a \f[V]module-info.java\f[R] file exists in the
|
||||||
|
\f[V]<source-root>\f[R] directory, its module declaration is used to
|
||||||
|
define a named module that will contain all the classes compiled from
|
||||||
|
\f[V].java\f[R] files in the source tree.
|
||||||
|
If \f[V]module-info.java\f[R] does not exist, all the classes compiled
|
||||||
|
from source files will be compiled in the context of the unnamed module.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
The source file should contain one or more top-level classes, the first
|
The source file that is launched should contain one or more top-level
|
||||||
of which is taken as the class to be executed.
|
classes, the first of which is taken as the class to be executed.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
The compiler does not enforce the optional restriction defined at the
|
For the source file that is launched, the compiler does not enforce the
|
||||||
end of JLS 7.6, that a type in a named package should exist in a file
|
optional restriction defined at the end of JLS 7.6, that a type in a
|
||||||
whose name is composed from the type name followed by the
|
named package should exist in a file whose name is composed from the
|
||||||
\f[V].java\f[R] extension.
|
type name followed by the \f[V].java\f[R] extension.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
If the source file contains errors, appropriate error messages are
|
If a source file contains errors, appropriate error messages are written
|
||||||
written to the standard error stream, and the launcher exits with a
|
to the standard error stream, and the launcher exits with a non-zero
|
||||||
non-zero exit code.
|
exit code.
|
||||||
.PP
|
.PP
|
||||||
\f[B]In source-file mode, execution proceeds as follows:\f[R]
|
\f[B]In source-file mode, execution proceeds as follows:\f[R]
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
The class to be executed is the first top-level class found in the
|
The class to be executed is the first top-level class found in the
|
||||||
source file.
|
source file.
|
||||||
It must contain a declaration of the standard
|
It must contain a declaration of an entry \f[V]main\f[R] method.
|
||||||
\f[V]public static void main(String[])\f[R] method.
|
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
The compiled classes are loaded by a custom class loader, that delegates
|
The compiled classes are loaded by a custom class loader, that delegates
|
||||||
to the application class loader.
|
to the application class loader.
|
||||||
This implies that classes appearing on the application class path cannot
|
This implies that classes appearing on the application class path cannot
|
||||||
refer to any classes declared in the source file.
|
refer to any classes declared in source files.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
The compiled classes are executed in the context of an unnamed module,
|
If a \f[V]module-info.java\f[R] file exists in the
|
||||||
as though \f[V]--add-modules=ALL-DEFAULT\f[R] is in effect.
|
\f[V]<source-root>\f[R] directory, then all the classes compiled from
|
||||||
|
\f[V].java\f[R] files in the source tree will be in that module, which
|
||||||
|
will serve as the root module for the execution of the program.
|
||||||
|
If \f[V]module-info.java\f[R] does not exist, the compiled classes are
|
||||||
|
executed in the context of an unnamed module, as though
|
||||||
|
\f[V]--add-modules=ALL-DEFAULT\f[R] is in effect.
|
||||||
This is in addition to any other \f[V]--add-module\f[R] options that may
|
This is in addition to any other \f[V]--add-module\f[R] options that may
|
||||||
be have been specified on the command line.
|
be have been specified on the command line.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
Any arguments appearing after the name of the file on the command line
|
Any arguments appearing after the name of the file on the command line
|
||||||
are passed to the standard main method in the obvious way.
|
are passed to the main method in the obvious way.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
It is an error if there is a class on the application class path whose
|
It is an error if there is a class on the application class path whose
|
||||||
name is the same as that of the class to be executed.
|
name is the same as that of the class to be executed.
|
||||||
.PP
|
.PP
|
||||||
See \f[B]JEP 330: Launch Single-File Source-Code Programs\f[R]
|
See \f[B]JEP 458: Launch Multi-File Source-Code Programs\f[R]
|
||||||
[https://openjdk.org/jeps/330] for complete details.
|
[https://openjdk.org/jeps/458] for complete details.
|
||||||
.SH USING THE JDK_JAVA_OPTIONS LAUNCHER ENVIRONMENT VARIABLE
|
.SH USING THE JDK_JAVA_OPTIONS LAUNCHER ENVIRONMENT VARIABLE
|
||||||
.PP
|
.PP
|
||||||
\f[V]JDK_JAVA_OPTIONS\f[R] prepends its content to the options parsed
|
\f[V]JDK_JAVA_OPTIONS\f[R] prepends its content to the options parsed
|
||||||
|
Loading…
x
Reference in New Issue
Block a user