Java
Chapter 5: Object-Oriented Programming 1. Why OOP ? 2. Java Constructor 3. Accessing Parent Class Variables 4. The Java OOP Concepts 5. Abstraction 6. Encapsulation 7. Polymorphism 8. Inheritance 9. Association 10. Aggregation 11. Composition 12.…
Java Method Overloading
We can easily understand about method of overloading by the below example:
Suppose we have to write a method to find the square of an integer number. We can write this method as follows:
public void intSquare (int number)
{
int square = number * number;
System.out.println("Method with Integer Argument Called: " + square);
}
We can easily understand about method of overloading by the below example:
Suppose we have to write a method to find the square of an integer number. We can write this method as follows:
public void intSquare (int number)
{
int square = number * number;
System.out.println("Method with Integer Argument Called: " + square);
}
If it is possible that a programmer has to take only one name and the program itself decides which method to use for which type of value, then it will be easier for the programmer to get the same. There is no need to memorise the names of more than one method for type work. In Java, we can give the above three methods the same name.
If we provide only the square () name instead of giving different names to the above three methods and write the rest of the description as follows, then Java’s Compiler does not generate any error.
If we provide only the square () name instead of giving different names to the above three methods and write the rest of the description as follows, then Java’s Compiler does not generate any error.
public void Square (int number)
{
int square = number * number;
System.out.println("Method with integer Argument Called: " + square);
}
public void Square(double number)
{
double square = number * number;
System.out.println("Method with double Argument Called: " + square);
}
public void Square(long number)
{
long square = number * number;
System.out.println("Method with long Argument Called: " + square);
}
{
int square = number * number;
System.out.println("Method with integer Argument Called: " + square);
}
public void Square(double number)
{
double square = number * number;
System.out.println("Method with double Argument Called: " + square);
}
public void Square(long number)
{
long square = number * number;
System.out.println("Method with long Argument Called: " + square);
}
class CalculateSquare
{
public void square()
{
System.out.println("No parameter Method Called");
}
public int square(int number)
{
int square = number * number;
System.out.println("Method with integer Argument called: " + square);
}
public float square(float number)
{
float square = number * number;
System.out.println("Method with float Argument Called: " + square);
}
public static void main(String[] args)
{
CalculateSquare obj = new CalculateSquare();
obj.square();
obj.square(5);
obj.square(2.5);
}
}
{
public void square()
{
System.out.println("No parameter Method Called");
}
public int square(int number)
{
int square = number * number;
System.out.println("Method with integer Argument called: " + square);
}
public float square(float number)
{
float square = number * number;
System.out.println("Method with float Argument Called: " + square);
}
public static void main(String[] args)
{
CalculateSquare obj = new CalculateSquare();
obj.square();
obj.square(5);
obj.square(2.5);
}
}
Note: We have not provided any argument in the ‘parenthesis’ of the square() method in our program. In this case, the Compiler Class calls the method in which no Parameter has been defined to achieve the Argument.
output:
In this way, we can define more than one Methods of the same name in a class, which is called Method Overloading, and
The Java compiler itself performs the appropriate Method Call for an object, based on the Data Type of the Arguments of the Methods.
output:
In this way, we can define more than one Methods of the same name in a class, which is called Method Overloading, and
The Java compiler itself performs the appropriate Method Call for an object, based on the Data Type of the Arguments of the Methods.
Benefits of using Method Overloading
Method overloading increases the readability of the program.
This provides flexibility to programmers so that they can call the same method for different types of data.
This makes the code look clean.
This reduces the execution time because the binding is done in compilation time itself.
Method overloading minimises the complexity of the code.
With this, we can use the code again, which saves memory.
Method overloading increases the readability of the program.
This provides flexibility to programmers so that they can call the same method for different types of data.
This makes the code look clean.
This reduces the execution time because the binding is done in compilation time itself.
Method overloading minimises the complexity of the code.
With this, we can use the code again, which saves memory.
Some points to remember about method overloading:
Method overloading cannot be done by changing the return type of methods.
The most important rule of method overloading is that two overloaded methods must have different parameters.
Method overloading has nothing to do with return-type
If there are two methods of the same signature within a class in the program, then Ambiguity Error comes, whether their return-type is different or not. This means that method overloading has no relation with return-type.
Method overloading cannot be done by changing the return type of methods.
The most important rule of method overloading is that two overloaded methods must have different parameters.
Method overloading has nothing to do with return-type
If there are two methods of the same signature within a class in the program, then Ambiguity Error comes, whether their return-type is different or not. This means that method overloading has no relation with return-type.