Skip to main content

polymorphism interview questions and answers in c#

Question: What is polymorphism in c#?
Answer: Polymorphism mean one object behaving as multiple forms. One object or function shows different behavior in different scenario is called polymorphism. For example : Dilip is a human object or function which talking behavior will change according his Father, Mother, Son, Boss etc.
In C# there are two types of polymorphism
1.  Static or Compile time
·         Function Overloading
·         operator overloading
2.  Run Time
·         Virtual function

Question: What is method overloading ?
Answer: When a class have more than one method with same but different signature is called method overloading.
For example:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication1
{

    class A
    {
       //1- Passed string parameter
        public void Add(string a, string b)
        {
            a = a + b;
            Console.WriteLine(a);
        }
       //2- Passed int parameter
        public void Add(int a, int b)
        {
            a = a + b;
            Console.WriteLine(a);
        }
        static void Main(string[] args)
        {
            A oA = new A();
            oA.add("Dilip","Singh");
            oA.add(10, 15);
        }
    }
}

Output:
DilipSingh
25

In above example Add is the same named function but parameter is different so when we call Add method passing parameter as string then Add method with string parameter will be access same as Add method with int parameter.

Question: What is method overriding?
Answer: To extend or modify the abstract or virtual implementation of inherited method, property, indexer or event is called overriding.
For example:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication1
{

    class Demo
    {
        static void Main(string[] args)
        {
            A oA;
            oA = new A();
            oA.Display();
            oA = new B();
            oA.Display();
        }
    }
    class A
    {
        public virtual void Display()
        {
            Console.WriteLine("Base class");
        }
    }
    class B : A
    {
        public override void Display()
        {
            Console.WriteLine("Derived class");
        }
    }
}

Question: When should be use method overloading?
 Answer:  When more than one method do same thing but take different parameter. eg Method Area(circle c). Area(Rectangle r).. the basic function is calculating area but with different structure.

Question: Advantage of Polymorphism?
Answer:
·         Invoking child class functions dynamically
·         Maintenance of code becomes easy.

Question: What is the difference between "new" and "override" keyword in inheritance chain ?
Answer:  Override: When a method of a base class is overridden in a derived class, the version in the derived class is used, even if the calling code didn't "know" that the object was an instance of the derived class.

New: If you use the new keyword instead of override, the method in the derived class doesn't override the method in the base class, it merely hides it.

Question: Will following code will compile? Why?
Answer:
A) class A
    {
        public  void Display()
        {
            Console.WriteLine("Base class");
        }
    }
    class B : A
    {
        public override void Display()
        {
            Console.WriteLine("Derived class");
        }
    }

Above code will not compile, because base class method should be mark with virtual class.
B)
class A
    {
        public void Display()
        {
            Console.WriteLine("Base class");
        }
    }
    class B : A
    {
        public new void Display()
        {
            Console.WriteLine("Derived class");
        }
    }
Yes above code will be compile because new keyword defines its own implementation and it's not related to base class method in any way.
C)
class A
    {
        public virtual void Display(ref int a)
        {
            Console.WriteLine("Base class");
        }
    }
    class B : A
    {
        public override void Display(out int a)
        {
            Console.WriteLine("Derived class");
        }
    }
Above code will give compile time error due to signature mismatch.
Question: What is the disadvantage of using virtual keyword?
Answer:
1.       Appropriate function calls are determined only at runtime.

2.       Since virtual keyword is used derived classes may ignore that base class implementations.


Popular posts from this blog

Check for changes to an SQL Server table?

Problem: Suppose your team is working on the under-development project so it might be possible continuous work on the database and perform changes in Table, Stored procedure as per requirement, and daily you have to update the testing server database as per changes are done in developing server database then how it is possible to trace those changes. There are a lot of solutions for this problem which is listed below Solution 1: For SQL Server 2000, 2005 and above use the CHECKSUM command SELECTCHECKSUM_AGG(BINARY_CHECKSUM(*))FROMYour_Table_NameWITH (NOLOCK); That will return the same number each time its run as long as the table contents haven't changed. Unfortunately CHECKSUM does not work always properly to detect changes. It is only a primitive checksum and no CRC calculation. Therefore you can't use it to detect all changes, e. g. symmetrical changes result in the same CHECKSUM! Solution 2: 1.Run the following query. Before executing query replace DB_Name with your database name…

How to drop multiple tables with common prefix in one query?

Problem: Suppose we have a situation where we need to drop those tables that have some prefixes string, so it is possible to drop those tables with a common prefix in a single query.
Solution: yes it is possible to drop all those tables that have the common prefix in a single query. Using following query you can delete all those tables that begin with a certain prefix string. In where condition just put the common prefix string in where condition (Like ‘prefix%’)
DECLARE@queryNVARCHAR(MAX)=N'';
SELECT@query+=' DROP TABLE ' +QUOTENAME(s.name) +'.'+QUOTENAME(t.name)+';' FROMsys.tablesASt INNERJOINsys.schemasASs ONt.[schema_id]=s.[schema_id] WHEREt.nameLIKE'MX_100%';
EXECsp_executesql@query;
This query may create an issue, if a table has a foreign key relationship, you'll either need to drop them first or arrange the output to drop the tables in a certain order. If you want to monitor exactly what goes on when the query is running then use the following que…

Merge and Merge join transformation in SSIS