Classpath is a parameter in the
Java Virtual Machine
A Java virtual machine (JVM) is a virtual machine that enables a computer to run Java programs as well as programs written in other languages that are also compiled to Java bytecode. The JVM is detailed by a specification that formally descr ...
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
An environment variable is a user-definable value that can affect the way running processes will behave on a computer. Environment variables are part of the environment in which a process runs. For example, a running process can query the va ...
.
Overview and architecture
Similar to the classic
dynamic loading behavior, when executing
Java
Java is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea (a part of Pacific Ocean) to the north. With a population of 156.9 million people (including Madura) in mid 2024, proje ...
programs, the
Java Virtual Machine
A Java virtual machine (JVM) is a virtual machine that enables a computer to run Java programs as well as programs written in other languages that are also compiled to Java bytecode. The JVM is detailed by a specification that formally descr ...
finds and loads classes lazily (it loads the
bytecode
Bytecode (also called portable code or p-code) is a form of instruction set designed for efficient execution by a software interpreter. Unlike human-readable source code, bytecodes are compact numeric codes, constants, and references (normal ...
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
Java is a set of computer software and specifications that provides a software platform for developing application software and deploying it in a cross-platform computing environment. Java is used in a wide variety of computing platforms fr ...
(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
Java is a set of computer software and specifications that provides a software platform for developing application software and deploying it in a cross-platform computing environment. Java is used in a wide variety of computing platforms ...
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
Supplying as application argument
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
Windows is a Product lining, product line of Proprietary software, proprietary graphical user interface, graphical operating systems developed and marketed by Microsoft. It is grouped into families and subfamilies that cater to particular sec ...
) or ''/home/user/myprogram'' (on
Linux
Linux ( ) is a family of open source Unix-like operating systems based on the Linux kernel, an kernel (operating system), operating system kernel first released on September 17, 1991, by Linus Torvalds. Linux is typically package manager, pac ...
).
The file structure looks like this:
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:
where:
*
java
is the
Java runtime launcher, a type of SDK Tool (A command-line tool, such as
javac,
javadoc
Javadoc (also capitalized as JavaDoc or javadoc) is an API documentation generator for the Java programming language. Based on information in Java source code, Javadoc generates documentation formatted as HTML and other formats via extensions. ...
, 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
The
environment variable
An environment variable is a user-definable value that can affect the way running processes will behave on a computer. Environment variables are part of the environment in which a process runs. For example, a running process can query the va ...
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
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:
Adding all JAR files in a directory
In
Java 6 and higher, one can add all jar-files in a specific directory to the classpath using wildcard notation.
Windows example:
Linux example:
This works for both
-classpath
options and environment classpaths.
Setting the path in a manifest file
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
In computer programming, a manifest file is a Data file, file containing metadata for a group of accompanying files that are part of a set or coherent unit. For example, the files of a computer program may have a manifest describing the name, Soft ...
defined in ''helloWorld.jar'' has this definition:
The
manifest file
In computer programming, a manifest file is a Data file, file containing metadata for a group of accompanying files that are part of a set or coherent unit. For example, the files of a computer program may have a manifest describing the name, Soft ...
should end with either a new line or carriage return.
The program is launched with the following command:
java -jar D:\myprogram\helloWorld.jar
pp 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 . ''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 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:
OS specific notes
Being closely associated with the file system, the
command-line Classpath syntax depends on the operating system.
For example:
* on all
Unix-like
A Unix-like (sometimes referred to as UN*X, *nix or *NIX) operating system is one that behaves in a manner similar to a Unix system, although not necessarily conforming to or being certified to any version of the Single UNIX Specification. A Uni ...
operating systems (such as
Linux
Linux ( ) is a family of open source Unix-like operating systems based on the Linux kernel, an kernel (operating system), operating system kernel first released on September 17, 1991, by Linus Torvalds. Linux is typically package manager, pac ...
and
Mac OS X
macOS, previously OS X and originally Mac OS X, is a Unix, Unix-based operating system developed and marketed by Apple Inc., Apple since 2001. It is the current operating system for Apple's Mac (computer), Mac computers. With ...
), the directory structure has a Unix syntax, with separate file paths separated by a
colon (":").
* on
Windows
Windows is a Product lining, product line of Proprietary software, proprietary graphical user interface, graphical operating systems developed and marketed by Microsoft. It is grouped into families and subfamilies that cater to particular sec ...
, the directory structure has a Windows syntax, and each file path must be separated by a
semicolon
The semicolon (or semi-colon) is a symbol commonly used as orthographic punctuation. In the English language, a semicolon is most commonly used to link (in a single sentence) two independent clauses that are closely related in thought, such as ...
(";").
This does not apply when the Classpath is defined in
manifest file
In computer programming, a manifest file is a Data file, file containing metadata for a group of accompanying files that are part of a set or coherent unit. For example, the files of a computer program may have a manifest describing the name, Soft ...
s, where each file path must be separated by a space (" "), regardless of the operating system.
See also
*
Java class loader
*
Java Platform Module System
*
References
{{Reflist
External links
Note explaining how Java classes are found, on Oracle website
Classpath