Saturday, 4 February 2012

The Object Class

The Object class sits at the top of the class hierarchy tree in the Java development environment. Every class in the Java system is a descendent (direct or indirect) of the Object class. The Object class defines the basic state and behavior that all objects must have, such as the ability to compare oneself to another object, to convert to a string, to wait on a condition variable, to notify other objects that a condition variable has changed, and to return the object's class.

The methods defined in the Object class are:

1.protected  Object     clone()
    Creates and returns a copy of this object.
    The method clone for class Object performs a specific cloning operation. First, if the class of this object does not implement the interface Cloneable, then a CloneNotSupportedException is thrown. Note that all arrays are considered to implement the interface Cloneable. Otherwise, this method creates a new instance of the class of this object and initializes all its fields with exactly the contents of the corresponding fields of this object, as if by assignment; the contents of the fields are not themselves cloned. Thus, this method performs a "shallow copy" of this object, not a "deep copy" operation.


2.boolean equals(Object obj)
    Indicates whether some other object is "equal to" this one.
    The equals method for class Object implements the most discriminating possible equivalence relation on objects; that is, for any reference values x and y, this method returns true if and only if x and y refer to the same object (x==y has the value true).

3.protected  void     finalize()
    Called by the garbage collector on an object when garbage collection determines that there are no more references to the object.
    A subclass overrides the finalize method to dispose of system resources or to perform other cleanup.

    The general contract of finalize is that it is invoked if and when the JVM has determined that there is no longer any means by which this object can be accessed by any thread. The finalize method may take any action, including making this object available again to other threads; the usual purpose of finalize, however, is to perform cleanup actions before the object is irrevocably discarded.

    The Java programming language does not guarantee which thread will invoke the finalize method for any given object. It is guaranteed, however, that the thread that invokes finalize will not be holding any user-visible synchronization locks when finalize is invoked. If an uncaught exception is thrown by the finalize method, the exception is ignored and finalization of that object terminates.

    After the finalize method has been invoked for an object, no further action is taken until the Java virtual machine has again determined that there is no longer any means by which this object can be accessed by any thread that has not yet died, including possible actions by other objects or classes which are ready to be finalized, at which point the object may be discarded.

    The finalize method is never invoked more than once by a Java virtual machine for any given object.

    Any exception thrown by the finalize method causes the finalization of this object to be halted, but is otherwise ignored.

4.Class getClass()
    Returns the runtime class of an object.
5.int hashCode()
    Returns a hash code value for the object.
6.void notify()
    Wakes up a single thread that is waiting on this object's monitor.
7.void notifyAll()
    Wakes up all threads that are waiting on this object's monitor.
8.String     toString()
    Returns a string representation of the object.

    The toString method for class Object returns a string consisting of the name of the class of which the object is an instance, the at-sign character `@', and the unsigned hexadecimal representation of the hash code of the object. In other words, this method returns a string equal to the value of:

    getClass().getName() + '@' + Integer.toHexString(hashCode())
    
9.void wait()
    Causes current thread to wait until another thread invokes the notify() method or the notifyAll() method for this object.
10.void wait(long timeout)
    Causes current thread to wait until either another thread invokes the notify() method or the notifyAll() method for this object, or a specified amount of time has elapsed.
11.void wait(long timeout, int nanos)
    Causes current thread to wait until another thread invokes the notify() method or the notifyAll() method for this object, or some other thread interrupts the current thread, or a certain amount of real time has elapsed.

No comments:

Post a Comment