Classpath: Difference between revisions
one example is plenty |
link fix |
||
(26 intermediate revisions by 19 users not shown) | |||
Line 1: | Line 1: | ||
{{For|the software|GNU Classpath}} |
|||
{{dablink|This article is about the argument on the command line of Java programs. For the Free Software Foundation's implementation of the Java [[Java Class Library|standard library]], see [[GNU Classpath]].}} |
|||
{{Multiple issues| |
{{Multiple issues| |
||
{{Primary sources|date= |
{{Primary sources|date=November 2020}} |
||
{{Howto|date= |
{{Howto|date=November 2020}} |
||
}} |
}} |
||
'''Classpath''' is a parameter in the [[Java Virtual Machine]] or the [[Java compiler]] that specifies the location of user-defined [[Class (computer science)|classes]] and [[Java package|packages]]. The parameter may be set either on the [[Command line interface|command-line]], or through an [[environment variable]]. |
'''Classpath''' is a parameter in the [[Java virtual machine|Java Virtual Machine]] or the [[Java compiler]] that specifies the location of user-defined [[Class (computer science)|classes]] and [[Java package|packages]]. The parameter may be set either on the [[Command line interface|command-line]], or through an [[environment variable]]. |
||
==Overview and architecture== |
== Overview and architecture == |
||
{{ |
{{See also|Java class loader}} |
||
Similar to the classic [[Library (computing)#Dynamic loading|dynamic loading]] behavior, when executing [[Java (programming language)|Java]] programs, the [[Java Virtual Machine]] finds and loads classes lazily (it loads the [[Java bytecode|bytecode]] of a class only when the class is first used). The classpath tells Java where to look in the filesystem for files defining these classes. |
Similar to the classic [[Library (computing)#Dynamic loading|dynamic loading]] behavior, when executing [[Java (programming language)|Java]] programs, the [[Java virtual machine|Java Virtual Machine]] finds and loads classes lazily (it loads the [[Java bytecode|bytecode]] of a class only when the class is first used). The classpath tells Java where to look in the filesystem for files defining these classes. |
||
The virtual machine searches for and loads classes in this order: |
The virtual machine searches for and loads classes in this order: |
||
# bootstrap classes: the classes that are fundamental to the [[Java Platform]] (comprising the public classes of the [[Java Class Library]], and the private classes that are necessary for this library to be functional). |
# bootstrap classes: the classes that are fundamental to the [[Java Platform]] (comprising the public classes of the [[Java Class Library]], and the private classes that are necessary for this library to be functional). |
||
# extension classes: [[Java package|packages]] that are in the ''extension'' directory of the [[ |
# extension classes: [[Java package|packages]] that are in the ''extension'' directory of the [[Java Runtime Environment]] or [[JDK]], <code>jre/lib/ext/</code> |
||
# user-defined packages and libraries |
# user-defined packages and libraries |
||
Line 80: | Line 80: | ||
* ''org.mypackage.HelloWorld'' is the name of the main class |
* ''org.mypackage.HelloWorld'' is the name of the main class |
||
===Setting the path through an environment variable=== |
=== Setting the path through an environment variable === |
||
The [[environment variable]] named <code>CLASSPATH</code> may be alternatively used to set the classpath. For the above example, we could also use on Windows: |
The [[environment variable]] named <code>CLASSPATH</code> may be alternatively used to set the classpath. For the above example, we could also use on Windows: |
||
< |
<syntaxhighlight lang="doscon"> |
||
set CLASSPATH=D:\myprogram |
D:\myprogram>set CLASSPATH=D:\myprogram |
||
java org.mypackage.HelloWorld |
D:\myprogram>java org.mypackage.HelloWorld |
||
</syntaxhighlight> |
|||
</source> |
|||
The rule is that <code>-classpath</code> option, when used to start the java application, overrides the <code>CLASSPATH</code> environment variable. If none are specified, the [[Working directory|current working directory]] is used as classpath. This means that when our working directory is <code>D:\myprogram\</code> (on Linux, <code>/home/user/myprogram/</code>), we would not need to specify the classpath explicitly. When overriding however, it is advised to include the current folder <code>"."</code> into the classpath in the case when loading classes from current folder is desired. |
The rule is that <code>-classpath</code> option, when used to start the java application, overrides the <code>CLASSPATH</code> environment variable. If none are specified, the [[Working directory|current working directory]] is used as classpath. This means that when our working directory is <code>D:\myprogram\</code> (on Linux, <code>/home/user/myprogram/</code>), we would not need to specify the classpath explicitly. When overriding however, it is advised to include the current folder <code>"."</code> into the classpath in the case when loading classes from current folder is desired. |
||
Line 103: | Line 103: | ||
---> org\ |
---> org\ |
||
| |
| |
||
--> mypackage\ |
---> mypackage\ |
||
| |
| |
||
---> HelloWorld.class |
---> HelloWorld.class |
||
Line 115: | Line 115: | ||
or alternatively: |
or alternatively: |
||
{{sxhl|2=doscon|1= |
|||
D:\myprogram>set CLASSPATH=D:\myprogram;D:\myprogram\lib\supportLib.jar |
|||
D:\myprogram>java org.mypackage.HelloWorld |
|||
}} |
|||
=== Adding all JAR files in a directory === |
=== Adding all JAR files in a directory === |
||
Line 123: | Line 124: | ||
Windows example: |
Windows example: |
||
{{sxhl|2=doscon|1= |
|||
<pre> |
|||
java -classpath ".;c:\mylib\*" MyApp |
D:\myprogram>java -classpath ".;c:\mylib\*" MyApp |
||
}} |
|||
</pre> |
|||
Linux example: |
Linux example: |
||
{{sxhl|2=console|1= |
|||
<pre> |
|||
java -classpath '.:/mylib/*' MyApp |
$ java -classpath '.:/mylib/*' MyApp |
||
}} |
|||
</pre> |
|||
This works for both <code>-classpath</code> options and environment classpaths. |
This works for both <code>-classpath</code> options and environment classpaths. |
||
Line 146: | Line 147: | ||
</pre> |
</pre> |
||
The [[manifest file]] defined in ''helloWorld.jar'' has this definition: |
The [[manifest file]] defined in ''helloWorld.jar'' has this definition: |
||
{{sxhl|2=properties| |
|||
<pre> |
|||
Main-Class: org.mypackage.HelloWorld |
Main-Class: org.mypackage.HelloWorld |
||
Class-Path: lib/supportLib.jar |
Class-Path: lib/supportLib.jar |
||
}} |
|||
</pre> |
|||
The [[manifest file]] should end with either a new line or carriage return. |
The [[manifest file]] should end with either a new line or carriage return. |
||
Line 159: | Line 160: | ||
Multiple classpath entries are separated with spaces: |
Multiple classpath entries are separated with spaces: |
||
{{sxhl|2=properties| |
|||
<pre> |
|||
Class-Path: lib/supportLib.jar lib/supportLib2.jar |
Class-Path: lib/supportLib.jar lib/supportLib2.jar |
||
}} |
|||
</pre> |
|||
== OS specific notes == |
== OS specific notes == |
||
Line 172: | Line 173: | ||
== See also == |
== See also == |
||
* [[Java |
* [[Java class loader]] |
||
* [[Java Module System]] |
* [[Java Platform Module System]] |
||
* {{Annotated link|rpath}} |
|||
==References== |
== References == |
||
{{Reflist}} |
{{Reflist}} |
||
Latest revision as of 01:58, 24 November 2024
This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these messages)
|
Classpath is a parameter in the Java Virtual Machine or the Java compiler that specifies the location of user-defined classes and packages. The parameter may be set either on the command-line, or through an environment variable.
Overview and architecture
[edit]Similar to the classic dynamic loading behavior, when executing Java programs, the Java Virtual Machine finds and loads classes lazily (it loads the bytecode of a class only when the class is first used). The classpath tells Java where to look in the filesystem for files defining these classes.
The virtual machine searches for and loads classes in this order:
- bootstrap classes: the classes that are fundamental to the Java Platform (comprising the public classes of the Java Class Library, and the private classes that are necessary for this library to be functional).
- extension classes: packages that are in the extension directory of the Java Runtime Environment or JDK,
jre/lib/ext/
- user-defined packages and libraries
By default only the packages of the JDK standard API and extension packages are accessible without needing to set where to find them. The path for all user-defined packages and libraries must be set in the command-line (or in the Manifest associated with the Jar file containing the classes).
Setting the path to execute Java programs
[edit]Supplying as application argument
[edit]Suppose we have a package called org.mypackage containing the classes:
- HelloWorld (main class)
- SupportClass
- UtilClass
and the files defining this package are stored physically under the directory D:\myprogram (on Windows) or /home/user/myprogram (on Linux).
The file structure looks like this:
Microsoft Windows | Linux |
---|---|
D:\myprogram\ | ---> org\ | ---> mypackage\ | ---> HelloWorld.class ---> SupportClass.class ---> UtilClass.class |
/home/user/myprogram/ | ---> org/ | ---> mypackage/ | ---> HelloWorld.class ---> SupportClass.class ---> UtilClass.class |
When we invoke Java, we specify the name of the application to run: org.mypackage.HelloWorld. However we must also tell Java where to look for the files and directories defining our package. So to launch the program, we use the following command:
Microsoft Windows | Linux |
---|---|
java -classpath D:\myprogram org.mypackage.HelloWorld |
java -cp /home/user/myprogram org.mypackage.HelloWorld |
where:
java
is the Java runtime launcher, a type of SDK Tool (A command-line tool, such as javac, javadoc, or apt)- -classpath D:\myprogram sets the path to the packages used in the program (on Linux, -cp /home/user/myprogram) and
- org.mypackage.HelloWorld is the name of the main class
Setting the path through an environment variable
[edit]The environment variable named CLASSPATH
may be alternatively used to set the classpath. For the above example, we could also use on Windows:
D:\myprogram>set CLASSPATH=D:\myprogram
D:\myprogram>java org.mypackage.HelloWorld
The rule is that -classpath
option, when used to start the java application, overrides the CLASSPATH
environment variable. If none are specified, the current working directory is used as classpath. This means that when our working directory is D:\myprogram\
(on Linux, /home/user/myprogram/
), we would not need to specify the classpath explicitly. When overriding however, it is advised to include the current folder "."
into the classpath in the case when loading classes from current folder is desired.
The same applies not only to java launcher but also to javac, the java compiler.
Setting the path of a Jar file
[edit]If a program uses a supporting library enclosed in a Jar file called supportLib.jar, physically located in the directory D:\myprogram\lib\ and the corresponding physical file structure is:
D:\myprogram\ | ---> lib\ | ---> supportLib.jar | ---> org\ | ---> mypackage\ | ---> HelloWorld.class ---> SupportClass.class ---> UtilClass.class
the following command-line option is needed:
java -classpath D:\myprogram;D:\myprogram\lib\supportLib.jar org.mypackage.HelloWorld
or alternatively:
D:\myprogram>set CLASSPATH=D:\myprogram;D:\myprogram\lib\supportLib.jar
D:\myprogram>java org.mypackage.HelloWorld
Adding all JAR files in a directory
[edit]In Java 6 and higher, one can add all jar-files in a specific directory to the classpath using wildcard notation.
Windows example:
D:\myprogram>java -classpath ".;c:\mylib\*" MyApp
Linux example:
$ java -classpath '.:/mylib/*' MyApp
This works for both -classpath
options and environment classpaths.
Setting the path in a manifest file
[edit]If a program has been enclosed in a Jar file called helloWorld.jar, located directly in the directory D:\myprogram, the directory structure is as follows:
D:\myprogram\ | ---> helloWorld.jar | ---> lib\ | ---> supportLib.jar
The manifest file defined in helloWorld.jar has this definition:
Main-Class: org.mypackage.HelloWorld
Class-Path: lib/supportLib.jar
The manifest file should end with either a new line or carriage return.
The program is launched with the following command:
java -jar D:\myprogram\helloWorld.jar [app arguments]
This automatically starts org.mypackage.HelloWorld specified in class Main-Class with the arguments. The user cannot replace this class name using the invocation java -jar
. Class-Path describes the location of supportLib.jar relative to the location of the library helloWorld.jar. Neither absolute file path, which is permitted in -classpath
parameter on the command line, nor jar-internal paths are supported. This means that if the main class file is contained in a jar, org/mypackage/HelloWorld.class must be a valid path on the root within the jar.
Multiple classpath entries are separated with spaces:
Class-Path: lib/supportLib.jar lib/supportLib2.jar
OS specific notes
[edit]Being closely associated with the file system, the command-line Classpath syntax depends on the operating system.[1] For example:
- on all Unix-like operating systems (such as Linux and Mac OS X), the directory structure has a Unix syntax, with separate file paths separated by a colon (":").
- on Windows, the directory structure has a Windows syntax, and each file path must be separated by a semicolon (";").
This does not apply when the Classpath is defined in manifest files, where each file path must be separated by a space (" "), regardless of the operating system.
See also
[edit]- Java class loader
- Java Platform Module System
- rpath – Hard-coded search path
References
[edit]- ^ "The Classpath". Retrieved 2016-06-26.