Thursday, April 26, 2012

Declaration and Access Control

Array Fundamentals
Arrays are used to represent fixed number of elements of the same type. The following are legal syntax for declaring one-dimensional arrays.int anArray[];
int[] anArray;
int []anArray;

It is important to note that the size of the array is not included in the declaration. Memory is allocated for an array using the new operator as shown below. 
anArray = new int[10]; 
The declaration and memory allocation may be combined together as shown below. 
int anArray[] = new int[10]; 
The elements of the array are implicitly initialized to default values based on array types (0 for integral types, null for objects etc.). This is true for both local arrays as well as arrays which are data members. In this respect arrays are different from normal variables. Variable defined inside a method are not implicitly initialized, where as array elements are implicitly initialized.
Array Initializations
Arrays are initialized using the syntax below 
int intArray[] = {1,2,3,4}; The length operator can be used to access the number of elements in an array (for example - intArray.length).
Multidimensional Arrays
The following are legal examples of declaration of a two dimensional array. 
int[] arr[];
int[][] arr;
int arr[][];
int []arr[];
When creating multi-dimensional arrays the initial index must be created before a later index. The following examples are legal.
int arr[][] = new int[5][5];
int arr[][] = new int[5][];

The following example will not compile;
int arr[][] = new int[][5];
Class Fundamentals
A class defines a new type and contains methods and variables. The example below illustrates a simple class.

class City {
   String name;      // member variable  
   String getName()    // member method
   {
      return name;
   }
   public static void main(String arg[]) {
   }
}

Method overloading
JavaTM technology allows two methods to have the same name as long as they have different signatures. The signature of a method consists of name of the method, and count and type of arguments of the method. Thus as long as the argument types of two methods are different, they may be over-loaded (have the same name).


Class constructors
Constructors are member methods that have same name as the class name. The constructor is invoked using the new operator when a class is created. If a class does not have any constructors then Java language compiler provides an implicit default constructor. The implicit default constructor does not have any arguments and is of the type - 
class_name() { }If a class defines one or more constructors, an implicit constructor is not provided. The example below gives a compilation error. 


class Test {
   int temp;
   Test(int x) {
      temp = x;
   }
   public static void main() {
      Test t = new Test(); /* This would generate a 
      compilation error, as there is no constructor 
      without any arguments. */
   }
}
Access Control In Java


 As you know, encapsulation links data with the code that manipulates it. However, encapsulation provides another important attribute: access control. Through encapsulation, you can control what parts of a program can access the members of a class. By controlling access, you can prevent misuse. For example, allowing access to data only through a well-defined set of methods, you can prevent the misuse of that data. Thus, when correctly implemented, a class creates a “black box” which may be used, but the inner workings of which are not open to tampering. However, the classes that were presented earlier do not completely meet this goal. For example, consider the Stack class shown at the end of the Recursion article. While it is true that the methods push() and pop() do provide a controlled interface to the stack, this interface is not enforced. That is, it is possible for another part of the program to bypass these methods and access the stack directly. Of course, in the wrong hands, this could lead to trouble. In this section you will be introduced to the mechanism by which you can precisely control access to the various members of a class.
             The access specifier that modifies its declaration determines how a member can be accessed. Java supplies a rich set of access specifiers. Some aspects of access control are related mostly to inheritance or packages. (A package is, essentially, a grouping of classes.) These parts of java’s access control mechanism will be discussed later. Here, let’s begin by examining access control as it applies to a single class. Once you understand the fundamentals of access control, the rest will be easy.
             Java’s access specifiers are public, private, and protected.  Java also defines a default access level. protected applies only when inheritance is involved. The other access specifiers are described next.
             Let’s begin by defining public and private. When a member of a class is modified by the public specifier, then that member can be accessed by any other code in your program. When a member of a class is specified as private, then that member can only be accessed by other members of its class. Now you can understand why main() has always been preceded by the public specifier. It is called by code that is outside the program that is, by the java run-time system. When no access specifier is used, then by default the member of a class is public within its own package, but cannot be accessed outside of its package.
             In the classes developed so far, all members of a class have used the default access mode, which is essentially public. However, this is not what you will typically want to be the case. Usually, you will want to restrict access to the data members of a class allowing access only through methods. Also, there will be times when you will want to define methods, which are private to a class.
             An access specifier precedes the rest of a member’s type specification. That is, it must begin a member’s declaration statement. Here is an example:
                public int i;
        private double j;
        private int myMethod(int a, char b) {//…
To understand the effects of public and private access, consider the following program:
class Test {
     int a;
     public int b;
     private int c;
      void setc(int i) {
          c = i;
     }
     int getc() {
          return c;
     }
}
class AccessTest {
     public static void main(String args[]) {
          Test ob = new Test ();
          ob.a = 10;
          ob.b = 20;
          ob.setc(100);
          System.out.println(“a, b, and c: “ + ob.a + ”  “ + ob.b+ “  “+ ob.getc());
     }
}
            As you can see, inside the Test class, a uses default access, which for this example is the same as specifying public. b is explicitly specified as public. Member c is given private access. This means that it cannot be accessed by code outside of its class. So, inside the AccessTest class, c cannot be used directly. It must be accessed through its public methods: setc() and getc(). If you were to remove the comment symbol from the beginning of the following line;
            ob.c = 100;
then you would not be able to compile this program because of the access violation.
            To see how access control can be applied to a more practical example, consider the following improved version of the Stack class shown at the end of the article Recursion.
class Stack {
     private int stck[] = new int [10];
     private int tos;
Stack() {
     tos = -1;
}
void push(int item) {
     if( tos==9)
          System.out.println(“Stack is full.”);
     else
          stck[++tos] = item;
}
int pop() {
     if(tos <0) {
          System.out.println(“Stack underflow.”);
          Return 0;
     }
     else
         return stck[tos--];
     }
}
As you can see, now both stck, which holds the stack, and tos, which is the index of the top of the stack, are specified as private. This means that they cannot be accessed or altered except through push() and pop(). Making tos private, for example, prevents other parts of your program from inadvertently setting it to a value that is beyond the end of the stck array.