Packages are used
in Java in-order to prevent naming conflicts, to control access, to make
searching/locating and usage of classes, interfaces, enumerations and
annotations easier etc.
A Package can be
defined as a grouping of related types(classes, interfaces, enumerations and
annotations ) providing access protection and name space management.
Some of the
existing packages in Java are::
- java.lang - bundles the
fundamental classes
- java.io - classes for input , output functions
are bundled in this package
Programmers can
define their own packages to bundle group of classes/interfaces etc. It is a
good practice to group related classes implemented by you so that a programmers
can easily determine that the classes, interfaces, enumerations, annotations
are related.
Since the package
creates a new namespace there won't be any name conflicts with names in other
packages. Using packages, it is easier to provide access control and it is also
easier to locate the related classed.
Creating a package:
When creating a
package, you should choose a name for the package and put a package
statement with that name at the top of every source file that contains the
classes, interfaces, enumerations, and annotation types that you want to
include in the package.
The package
statement should be the first line in the source file. There can be only one
package statement in each source file, and it applies to all types in the file.
If a package
statement is not used then the class, interfaces, enumerations, and annotation
types will be put into an unnamed package.
Example:
Let us look at an
example that creates a package called animals. It is common practice to
use lowercased names of packages to avoid any conflicts with the names of
classes, interfaces.
Put an interface
in the package animals:
/* File name :
Animal.java */
package animals;
interface Animal {
public void eat();
public void travel();
}
|
Now put an
implementation in the same package animals:
package animals;
/* File name :
MammalInt.java */
public class MammalInt
implements Animal{
public void eat(){
System.out.println("Mammal
eats");
}
public void travel(){
System.out.println("Mammal
travels");
}
public int noOfLegs(){
return 0;
}
public static void main(String args[]){
MammalInt m = new MammalInt();
m.eat();
m.travel();
}
}
|
Now you compile
these two files and put them in a sub-directory called animals and try
to run as follows:
$ mkdir animals
$ cp Animal.class MammalInt.class animals
$ java
animals/MammalInt
Mammal eats
Mammal travels
|
The import Keyword:
If a class wants
to use another class in the same package, the package name does not need to be
used. Classes in the same package find each other without any special syntax.
Example:
Here a class
named Boss is added to the payroll package that already contains Employee. The
Boss can then refer to the Employee class without using the payroll prefix, as
demonstrated by the following Boss class.
package payroll;
public class Boss
{
public void payEmployee(Employee e)
{
e.mailCheck();
}
}
|
What happens if
Boss is not in the payroll package? The Boss class must then use one of the
following techniques for referring to a class in a different package.
- The fully qualified name of the class can
be used. For example:
payroll.Employee
|
- The package can be imported using the
import keyword and the wild card (*). For example:
import payroll.*;
|
- The class itself can be imported using the
import keyword. For example:
import
payroll.Employee;
|
Note: A class file can
contain any number of import statements. The import statements must appear
after the package statement and before the class declaration.
The Directory Structure
of Packages:
Two major results
occur when a class is placed in a package:
- The name of the package becomes a part of
the name of the class, as we just discussed in the previous section.
- The name of the package must match the
directory structure where the corresponding bytecode resides.
Here is simple
way of managing your files in java:
Put the source
code for a class, interface, enumeration, or annotation type in a text file
whose name is the simple name of the type and whose extension is .java.
For example:
// File Name : Car.java
package vehicle;
public class Car {
// Class implementation.
}
|
Now put the
source file in a directory whose name reflects the name of the package to which
the class belongs:
....\vehicle\Car.java
|
Now the qualified
class name and pathname would be as below:
- Class name -> vehicle.Car
- Path name -> vehicle\Car.java (in
windows)
In general a
company uses its reversed Internet domain name for its package names. Example:
A company's Internet domain name is apple.com, then all its package names would
start with com.apple. Each component of the package name corresponds to a
subdirectory.
Example: The
company had a com.apple.computers package that contained a Dell.java source
file, it would be contained in a series of subdirectories like this:
....\com\apple\computers\Dell.java
|
At the time of
compilation, the compiler creates a different output file for each class,
interface and enumeration defined in it. The base name of the output file is
the name of the type, and its extension is .class
For example:
// File Name:
Dell.java
package
com.apple.computers;
public class Dell{
}
class Ups{
}
|
Now compile this
file as follows using -d option:
$javac -d . Dell.java
|
This would put
compiled files as follows:
.\com\apple\computers\Dell.class
.\com\apple\computers\Ups.class
|
You can import
all the classes or interfaces defined in \com\apple\computers\ as
follows:
import
com.apple.computers.*;
|
Like the .java
source files, the compiled .class files should be in a series of directories
that reflect the package name. However, the path to the .class files does not
have to be the same as the path to the .java source files. You can arrange your
source and class directories separately, as:
<path-one>\sources\com\apple\computers\Dell.java
<path-two>\classes\com\apple\computers\Dell.class
|
By doing this, it
is possible to give the classes directory to other programmers without
revealing your sources. You also need to manage source and class files in this
manner so that the compiler and the Java Virtual Machine (JVM) can find all the
types your program uses.
The full path to
the classes directory, <path-two>\classes, is called the class path, and
is set with the CLASSPATH system variable. Both the compiler and the JVM
construct the path to your .class files by adding the package name to the class
path.
Say
<path-two>\classes is the class path, and the package name is
com.apple.computers, then the compiler and JVM will look for .class files in
<path-two>\classes\com\apple\comptuers.
A class path may
include several paths. Multiple paths should be separated by a semicolon
(Windows) or colon (Unix). By default, the compiler and the JVM search the
current directory and the JAR file containing the Java platform classes so that
these directories are automatically in the class path.
Set CLASSPATH System
Variable:
To display the
current CLASSPATH variable, use the following commands in Windows and Unix
(Bourne shell):
- In Windows -> C:\> set CLASSPATH
- In Unix -> % echo $CLASSPATH
To delete the
current contents of the CLASSPATH variable, use :
- In Windows -> C:\> set CLASSPATH=
- In Unix -> % unset CLASSPATH; export
CLASSPATH
To set the
CLASSPATH variable:
- In Windows -> set
CLASSPATH=C:\users\jack\java\classes
- In Unix -> %
CLASSPATH=/home/jack/java/classes; export CLASSPATH
No comments:
Post a Comment