Skip to main content

constructor overloading in c++

Constructor play an important part in c++. They can initialize the values of a given object to some known values. This is important as constructor will be able to set some values in objects which otherwise may have some garbage values. Most uninitialized value in objects are main cause of the bugs.
But the concept of constructor can allow us to do just anything beside initializing values. Constructor are always called when an object is created. This property of constructor is very useful in situation when you need to perform some task as soon as an object is created.
So constructor is a special function that gets called automatically when an object is created. This function can like any other function do anything (like initializing values).
Overloading Constructor :
This process is very similar to the overloading of simple functions. Since constructor are also function , they can be overloaded like any other functions. This allows user to create many constructor, which can help user to create (and set) objects differently. In most cases objects have data member set to private (so user can't directly change the values of the objects). Different constructor can allow creation of objects with desired type of values.
Method :
Overloading a constructor is very similar to function overloading. Just change the signature (no. of args and type of args) of the constructor.
Overloaded Constructor Usage::
<class name> <objectname>(args);
like Box b; or Box b2(9);

Code:


#include<iostream>

using namespace std;

class box
{
    //data member  are private
    int width,height,length;
    
    public:
    
    box()
    {
        //default constructor 
        //initializes values to 0;
        width=height=length=0;
    }
    box(int k)
    {
        //overloaded constructor with one argument
        //will initialize all 3 data member to value 'k'
        width=height=length=k;
    }
    box(int x,int y,int z)
    {
        //overloaded constructor with 3 argument
        //will initialize data member differently
        width=x;
        height=y;
        length=z;
    }
    void show()
    {
        //function to show these values
        cout<<"\n Width="<<width;
        cout<<"\n Height="<<height;
        cout<<"\n Length="<<length;
    }
    
};

int main()
{
    box b;//using default constructor
    box b2(9);//using 1st overloaded constructor
    box b3(1,2,3);//using 2nd overloaded constructor
    
    b.show();
    b2.show();
    b3.show();
}

Popular posts from this blog

Overloading Unary Operator in C++

In this Example I will demonstrate overloading a unary operator. The overloading is done in similar way as we did for binary operator. In this example I will be using a Vector Class. The operator we are going to over load is the unary "~" (tilde) operator. although you can use any unary overloadable operator. Method: In this example the overloaded operator will be the part of the class i.e. the over loaded definition will be a member function. (As we know overloading can be done using non member functions too). So the unary operator will not have any arguments in it. We will overload ~ operator so that it will reflect the vector so that its z component becomes x component and vice versa. So input vector will be 2i+3j+5k and its output vector will be 5i+3j+2k. although you can do anything you like. Code: # include < iostream > using namespace std ; class vector { int x , y , z ;      public : vector ( ) { x = y = z = 0 ; ...

Program to find nth Prime number in C

Objective: To print any Prime number in C.  This task may sound easy but is a very good exercise to help optimize CPU intensive programs. Finding Prime number is a very CPU hogging task and it becomes even more dreaded as the number starts to grow. Lets say we want to find 30001th prime. how will we find it?? Here is the program. Programming logic : The easiest method is to check if the given number N is divisible by any number from 2 to N-1. But it may be noted that we don't need to go beyond the number that is square root of N.  why?? lets have a look. Say we are testing number 49 for prime number. Our objective is to find any number that may divide it. so we start from 2,3,4 etc. As soon as we cross 7 there will be no number that will divide 49, if there was we have got it earlier since it will be smaller then 7.  Get it? another example 64 : 2x32 4x16 8x8 16x4 32x2 as you can see when we pass number 8 we don't need to test as the number that will come ,...