Classpath
   HOME

TheInfoList



OR:

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 describes ...
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

Similar to the classic
dynamic loading Dynamic loading is a mechanism by which a computer program can, at run time, load a library (or other binary) into memory, retrieve the addresses of functions and variables contained in the library, execute those functions or access those varia ...
behavior, when executing Java 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 describes ...
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 (norma ...
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 Manifest may refer to: Computing * Manifest file, a metadata file that enumerates files in a program or package * Manifest (CLI), a metadata text file for CLI assemblies Events * Manifest (convention), a defunct anime festival in Melbourne, Aust ...
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) or ''/home/user/myprogram'' (on Linux). 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 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 describes ...
launcher, a type of SDK Tool (A command-line tool, such as javac, javadoc, or
apt Apt. is an abbreviation for apartment. Apt may also refer to: Places * Apt Cathedral, a former cathedral, and national monument of France, in the town of Apt in Provence * Apt, Vaucluse, a commune of the Vaucluse département of France * A ...
) * ''-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 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 A command-line interpreter or command-line processor uses a command-line interface (CLI) to receive commands from a user in the form of lines of text. This provides a means of setting parameters for the environment, invoking executables and pro ...
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 The Java language has undergone several changes since JDK 1.0 as well as numerous additions of classes and packages to the standard library. Since J2SE 1.4, the evolution of the Java language has been governed by the Java Community P ...
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 defined in ''helloWorld.jar'' has this definition: 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 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 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

* Java Classloader *
Java Platform Module System The Java Platform Module System specifies a distribution format for collections of Java code and associated resources. It also specifies a repository for storing these collections, or '' modules'', and identifies how they can be discovered, loaded ...


References

{{Reflist


External links


Note explaining how Java classes are found, on Oracle website


Classpath