The JavaTM Tutorial
Previous Page Lesson Contents Next Page Start of Tutorial > Start of Trail > Start of Lesson Search
Feedback Form

Trail: Learning the Java Language
Lesson: Object Basics and Simple Data Objects

Creating Objects

As you know, a class (in the Learning the Java Language trail) provides the blueprint for objects (in the Learning the Java Language trail) ; you create an object from a class. Each of the following statements taken from the CreateObjectDemo (in a .java source file) program creates an object and assigns it to a variable:
Point originOne = new Point(23, 94);
Rectangle rectOne = new Rectangle(originOne, 100, 200);
Rectangle rectTwo = new Rectangle(50, 100);
The first line creates an object from the Point (in a .java source file) class and the second and third lines each create an object from the Rectangle (in a .java source file) class.

Each statement has the following three parts:

  1. Declaration: The code set in bold are all variable declarations that associate a variable name with an object type.
  2. Instantiation: The new keyword is a Java operator that creates the object. As discussed below, this is also known as instantiating a class.
  3. Initialization: The new operator is followed by a call to a constructor. For example, Point(23, 94) is a call to Point's only constructor. The constructor initializes the new object.
The next three subsections discuss each of these actions in detail:

Declaring a Variable to Refer to an Object

From the Variables (in the Learning the Java Language trail) section in the previous lesson, you learned that to declare a variable, you write:
type name
This notifies the compiler that you will use name to refer to data whose type is type. The Java programming language divides variable types into two main categories: primitive types, and reference types.

Variables of primitive types (byte, short, int, long, char, float, double, or boolean) always hold a primitive value of that same type.

Variables of reference types, however, are slightly more complex. They may be declared in any of the following ways:

You can also declare a variable on its own line, such as:

MyClass myObject;
When you use this approach on a local variable, you cannot assume the initial value of myObject — local variables are not initialized. When you use this approach on a field, the value of myObject will be automatically set to null until an object is actually created and assigned to it. Remember, variable declaration alone does not actually create an object. For that, you need to use the new operator, as described in the next section.

A variable in this state, which currently references no object, is said to hold a null reference. If the code in CreateObjectDemo (in a .java source file) had declared its originOne variable in this manner, it could be illustrated as follows (variable name, plus reference pointing to nothing):

originOne is null.

A variable of reference type may also hold an object reference, as discussed in the following sections.

Instantiating a Class

The new operator instantiates a class by allocating memory for a new object.


Note: The phrase "instantiating a class" means the same thing as "creating an object"; you can think of the two as being synonymous. When you create an object, you are creating an instance of a class, therefore "instantiating" a class.

The new operator requires a single, postfix argument: a call to a constructor. The name of the constructor provides the name of the class to instantiate. The constructor initializes the new object.

The new operator returns a reference to the object it created. Often, this reference is assigned to a variable of the appropriate type.

Initializing an Object

Here's the code for the Point class:
public class Point {
    public int x = 0;
    public int y = 0;
    //A constructor!
    public Point(int x, int y) {
        this.x = x;
        this.y = y;
    }
}
This class contains a single constructor. You can recognize a constructor because it has the same name as the class and has no return type. The constructor in the Point class takes two integer arguments, as declared by the code (int x, int y). The following statement provides 23 and 94 as values for those arguments:
Point originOne = new Point(23, 94);
The effect of the previous line of code can be illustrated in the next figure:

originOne now points to a Point object.

Here's the code for the Rectangle class, which contains four constructors:
public class Rectangle {
    /** The width of this rectangle. */
    public int width;

    /** The height of this rectangle. */
    public int height;

    /** The origin (lower-left corner) of this rectangle. */
    public Point origin;

    /**
     * Creates a rectangle with the specified size.
     * The origin is (0, 0).
     * @param w width of the rectangle
     * @param h height of the rectangle
     */
    public Rectangle(int w, int h) {
	this(new Point(0, 0), w, h);
    }

    /**
     * Creates a rectangle with the specified origin and
     * size.
     * @param p origin of the rectangle
     * @param w width of the rectangle
     * @param h height of the rectangle
     */
    public Rectangle(Point p, int w, int h) {
	origin = p;
	width = w;
	height = h;
    }

    /**
     * Moves the rectangle to the specified origin.
     */
    public void move(int x, int y) {
	origin.x = x;
	origin.y = y;
    }

    /**
     * Returns the computed area of the rectangle.
     */
    public int area() {
	return width * height;
    }
}
Each constructor lets you provide initial values for the rectangle's size and width, using both primitive and reference types. If a class has multiple constructors, they all have the same name but a different number of arguments or different typed arguments. The Java compiler differentiates the constructors based on the number and the type of the arguments. When the Java compiler encounters the following code, it knows to call the constructor in the Rectangle class that requires a Point argument followed by two integer arguments:
 
Rectangle rectOne = new Rectangle(originOne, 100, 200);
This calls one of Rectangle's constructors which initializes origin to originOne. Also, the constructor sets width to 100 and height to 200. Now there are two references to the same Point object; an object can have multiple references to it, as shown in the next figure:

Now the rectangle's origin field also points to the Point.

The following line of code calls the constructor that requires two integer arguments, which provide the initial values for width and height. If you inspect the code within the constructor, you will see that it creates a new Point object whose x and y values are initialized to 0:
Rectangle rectTwo = new Rectangle(50, 100);
The Rectangle constructor used in the following statement doesn't take any arguments, so it's called a no-argument constructor:
Rectangle rect = new Rectangle();
If a class does not explicitly declare any constructors, the Java compiler automatically provides a no-argument constructor, called the default constructor, that calls the parent's no-argument constructor. If the parent has no such constructor, the compiler will reject the program. Thus, all classes have at least one constructor.

This section talked about how to use a constructor.The section Providing Constructors for Your Classes (in the Learning the Java Language trail) explains how to write constructors for your classes.


Previous Page Lesson Contents Next Page Start of Tutorial > Start of Trail > Start of Lesson Search
Feedback Form

Copyright 1995-2005 Sun Microsystems, Inc. All rights reserved.