Introduction
In this post, you will learn the following topics:
- Polymorphism
- Static or compile time polymorphism
- Method overloading
- Dynamic or runtime polymorphism
- Method overriding
- Virtual keyword and virtual method
- Difference between method overriding and method hiding
- Sealed method
What is Polymorphism?
Polymorphism means one name many forms. Polymorphism means one object behaving as multiple forms. One function behaves in different forms. In other words, "Many forms of a single object is called Polymorphism."
Real World Example of Polymorphism
Example 1
- A Teacher behaves with student.
- A Teacher behaves with his/her seniors.
Here teacher is an object but the attitude is different in different situations.
Example 2
- Person behaves as a SON in house, at the same time that person behaves like an EMPLOYEE in the office.
Example 3
Your mobile phone, one name but many forms:
- As phone
- As camera
- As mp3 player
- As radio
With polymorphism, the same method or property can perform different actions depending on the run-time type of the instance that invokes it.
There are two types of polymorphism:
- Static or compile time polymorphism
- Dynamic or runtime polymorphism
Static or Compile Time Polymorphism
In static polymorphism, the decision is made at compile time.
- Which method is to be called is decided at compile-time only.
- Method overloading is an example of this.
- Compile time polymorphism is method overloading, where the compiler knows which overloaded method it is going to call.
Method overloading is a concept where a class can have more than one method with the same name and different parameters.
Compiler checks the type and number of parameters passed on to the method and decides which method to call at compile time and it will give an error if there are no methods that match the method signature of the method that is called at compile time.
Example
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Polymorphism
{
class Program
{
public class TestOverloading
{
public void Add(string a1, string a2)
{
Console.WriteLine("Adding Two String :" + a1 + a2);
}
public void Add(int a1, int a2)
{
Console.WriteLine("Adding Two Integer :" + (a1 + a2));
}
public void Add(int a1, string a2)
{
Console.WriteLine("Adding one Integer and one string :" + a1 + a2);
}
public void Add(string a1, int a2)
{
Console.WriteLine("Adding one string and on Integer :" + a1 + a2);
}
}
static void Main(string[] args)
{
TestOverloading obj = new TestOverloading();
obj.Add("Rakesh ", "Kumar");
obj.Add(5, 10);
obj.Add(10, "Rakesh");
obj.Add("Rakesh", 10);
Console.ReadLine();
}
}
}
Output :-
Adding Two String :Rakesh Kumar
Adding Two Integer :15
Adding one Integer and one string : 10Rakesh
Adding one string and on Integer : Rakesh10
If we change the sequence of the
parameter in the method then it will work.
public void Add(int a1, string a2)
{
Console.WriteLine("Adding one Integer and one string :" + a1 + a2);
}
public void Add(string a1, int a2)
{
Console.WriteLine("Adding one string and on Integer :" + a1 + a2);
}
Dynamic or Runtime Polymorphism
Run-time polymorphism is achieved by method overriding.
Method overriding allows us to have methods in the base and derived classes with the same name and the same parameters.
By runtime polymorphism, we can point to any derived class from the object of the base class at runtime that shows the ability of runtime binding.
Through the reference variable of a base class, the determination of the method to be called is based on the object being referred to by reference variable.
Compiler would not be aware whether the method is available for overriding the functionality or not. So compiler would not give any error at compile time. At runtime, it will be decided which method to call and if there is no method at runtime, it will give an error.
See the following example:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Overriding
{
class Program
{
public class Base
{
public virtual void show()
{
Console.WriteLine("Show From Base Class.");
}
}
public class Drived :Base
{
public override void show()
{
Console.WriteLine("Show From Drived Class.");
}
}
static void Main(string[] args)
{
Base objbase = new Base();
objbase.show(); // Outpur ---> Show from Base Class.
Drived objdrived = new Drived();
objdrived.show(); // Outpur ---> Show From Drived Class.
Base objbase1 = new Drived();
objbase1.show(); // Outpur ---> Show From Drived Class.
//Drived objdrived1 = new Base();
//objdrived1.show(); // /*compile time error. Cannot implicitly convert type 'BaseClass' to 'DerivedClass'. An explicit conversion exists (are you missing a cast?)*/
Console.ReadLine();
}
}
}
Compiler demands virtual
Show()
method and it compiles successfully. The right version of Show()
method cannot be determined until run-time since only at that time Base objBase
is initialized as Derived
.Virtual Keyword
Virtual method is a method whose behavior can be overridden in derived class. Virtual method allows declare a method in base class that can be redefined in each derived class.
When a virtual method is invoked, the run-time type of the object is checked for an overriding member. The overriding member in the most derived class is called, which might be the original member, if no derived class has overridden the member.
- By default, methods are non-virtual. You cannot override a non-virtual method.
- You cannot use the virtual modifier with the
static
,abstract
,private
oroverride
modifiers. - Virtual properties behave like
abstract
methods, except for the differences in declaration and invocation syntax. - It is an error to use the
virtual
modifier on astatic
property. - A
virtual
inherited property can be overridden in a derived class by including a property declaration that uses the override modifier.
Virtual
method solves the following problem:
In OOP, when a derived class inherits from a base class, an object of the derived class may be referred to (or cast) as either being the base class type or the derived class type. If there are base class methods overridden by the derived class, the method call behavior is ambiguous.
In C#, polymorphism is explicit - you must have a
virtual
(or abstract
) modifier on the base class method (member) and an override on the derived class method, which you probably already know.
If you don't put a modifier on a base class method, polymorphism can't ever happen. If you then add a non-modified method to the derived class with the same signature as the non-modified base class method, the compiler will generate a Warning message.
See the following example:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Overriding
{
class Program
{
public class Base
{
public virtual void show()
{
Console.WriteLine("Show From Base Class.");
}
}
public class Drived :Base
{
/* Warning 1 'Overriding.Program.Drived.show()' hides inherited member 'Overriding.Program.Base.show()'.
* To make the current member override that implementation, add the override keyword. Otherwise add the new keyword.
*/
public void show()
{
Console.WriteLine("Show From Drived Class.");
}
}
static void Main(string[] args)
{
Base objbase = new Base();
objbase.show(); // Outpur ---> Show from Base Class.
Drived objdrived = new Drived();
objdrived.show(); // Outpur ---> Show From Drived Class.
Base objbase1 = new Drived();
objbase1.show(); // Outpur ---> Show From Base Class.
//Drived objdrived1 = new Base();
//objdrived1.show(); // Output --------> Give Error
Console.ReadLine();
}
}
}
It means that you are hiding (re-defining) the base class method.
Difference between Method Overriding and Method Hiding
Method overriding allows a subclass to provide a specific implementation of a method that is already provided by base class. The implementation in the subclass overrides (replaces) the implementation in the base class.
The important thing to remember about overriding is that the method that is doing the overriding is related to the method in the base class.
When a virtual method is called on a reference, the actual type of the object to which the reference refers is used to determine which method implementation should be used. When a method of a base class is overridden in a derived class (subclass), the version defined in the derived class is used. This is so even should the calling application be unaware that the object is an instance of the derived class.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Overriding
{
class Program
{
public class Base
{
public virtual void show()
{
Console.WriteLine("Show From Base Class.");
}
}
public class Drived :Base
{
public override void show()
{
Console.WriteLine("Show From Drived Class.");
}
}
static void Main(string[] args)
{
Base objbase = new Base();
objbase.show(); // Outpur ---> Show from Base Class.
Drived objdrived = new Drived();
objdrived.show(); // Outpur ---> Show From Drived Class.
Base objbase1 = new Drived();
objbase1.show(); // Outpur ---> Show From Drived Class.
//Drived objdrived1 = new Base();
//objdrived1.show(); // Output --------> Give Error
Console.ReadLine();
}
}
}
Method hiding does not have a relationship between the methods in the base class and derived class. The method in the derived class hides the method in the base class.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Overriding
{
class Program
{
public class Base
{
public virtual void show()
{
Console.WriteLine("Show From Base Class.");
}
}
public class Drived :Base
{
public new void show()
{
Console.WriteLine("Show From Drived Class.");
}
}
static void Main(string[] args)
{
Base objbase = new Base();
objbase.show(); // Outpur ---> Show from Base Class.
Drived objdrived = new Drived();
objdrived.show(); // Outpur ---> Show From Drived Class.
Base objbase1 = new Drived();
objbase1.show(); // Outpur ---> Show From Base Class.
//Drived objdrived1 = new Base();
//objdrived1.show(); // Output --------> Give Error
Console.ReadLine();
}
}
}
Ref :- http://www.codeproject.com/
No comments:
Post a Comment