|
|||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||
|
Announcements
Want a new Job?
Chapters
Services
Feature Zones
|
IntroductionBroadly speaking, a constructor is a method in the class which gets executed when its object is created. Usually, we put the initialization code in the constructor. Writing a constructor in the class is damn simple, have a look at the following sample: public class mySampleClass
{
public mySampleClass()
{
// This is the constructor method.
}
// rest of the class members goes here.
}
When the object of this class is instantiated, this constructor will be executed. Something like this: mySampleClass obj = new mySampleClass()
// At this time the code in the constructor will // be executed
Constructor OverloadingC# supports overloading of constructors, that means, we can have constructors with different sets of parameters. So, our class can be like this: public class mySampleClass
{
public mySampleClass()
{
// This is the no parameter constructor method.
// First Constructor
}
public mySampleClass(int Age)
{
// This is the constructor with one parameter.
// Second Constructor
}
public mySampleClass(int Age, string Name)
{
// This is the constructor with two parameters.
// Third Constructor
}
// rest of the class members goes here.
}
Well, note here that call to the constructor now depends on the way you instantiate the object. For example: mySampleClass obj = new mySampleClass()
// At this time the code of no parameter
// constructor (First Constructor)will be executed
mySampleClass obj = new mySampleClass(12)
// At this time the code of one parameter
// constructor(Second Constructor)will be
// executed.
The call to the constructors is completely governed by the rules of overloading here. Calling Constructor from another ConstructorYou can always make a call to one constructor from within another. Say, for example: public class mySampleClass
{
public mySampleClass(): this(10)
{
// This is the no parameter constructor method.
// First Constructor
}
public mySampleClass(int Age)
{
// This is the constructor with one parameter.
// Second Constructor
}
}
Very first of all, let us see what is this syntax: public mySampleClass(): this(10)
Here, Another thing which we must know is the execution sequence i.e., which method will be executed when. Here, if I instantiate the object as: mySampleClass obj = new mySampleClass()
Then the code of public mySampleClass(): this(10)
{
// This is the no parameter constructor method.
// First Constructor
}
is equivalent to: public mySampleClass()
{
mySampleClass(10)
// This is the no parameter constructor method.
// First Constructor
}
Note: Above (just above this line) code is mentioned there for pure analogy and will not compile. The intention here is to tell the flow of execution if initializers are used. We cannot make an explicit call to the constructors in C#, treating them as if any simple method, for example: statement For the VB.NET programmers: you can make the call to another constructor of the same class by the syntax Note that only This is sometimes called Constructor chaining. Huff… Simple thing made tough, but this is how it is. Anyway, let us proceed further. Behavior of Constructors in InheritanceLet us first create the inherited class. public class myBaseClass
{
public myBaseClass()
{
// Code for First Base class Constructor
}
public myBaseClass(int Age)
{
// Code for Second Base class Constructor
}
// Other class members goes here
}
public class myDerivedClass : myBaseClass
// Note that I am inheriting the class here.
{
public myDerivedClass()
{
// Code for the First myDerivedClass Constructor.
}
public myDerivedClass(int Age):base(Age)
{
// Code for the Second myDerivedClass Constructor.
}
// Other class members goes here
}
Now, what will be the execution sequence here: If I create the object of the derived class as: myDerivedClass obj = new myDerivedClass()
Then the sequence of execution will be:
Note: If we do not provide initializer referring to the base class constructor then it executes the no parameter constructor of the base class. Note one thing here: we are not making any explicit call to the constructor of base class neither by initializer nor by the If I create an object of the derived class as: myDerivedClass obj = new myDerivedClass(15)
Then the sequence of execution will be:
Here, the new keyword Also note the usage of Private ConstructorsPrivate constructors, the constructors with the " Say for example, my class is something like this : public class myClass
{
private MyClass()
{
Console.WriteLine("This is no parameter Constructor");
}
public MyClass(int var):this()
{
Console.WriteLine("This is one parameter Constructor");
}
// Other class methods goes here
}
Then we can create the object of this class by the statement: MyClass obj = new MyClass(10);
The above statement will work fine, but the statement MyClass obj = new MyClass();
will raise an error : It is possible to have the class with only the private constructors. But yes as I said, such class can neither be instantiated nor be inherited. If we try to inherit the class with only private constructors then we will get the same error as above. Also recall, once you provide constructor from your side the compiler will not add the no-parameter public constructor to your class. Well, one of the usage scenarios of such class could be – when you have only static members in the class and you don't need to instantiate it. Phew… lost… Anything left in constructors? Yes, Static Constructors. Ha!! Now, what are they? Let us see.. Static ConstructorsThis is a new concept introduced in C#. By new here, I mean that it was not available for the C++ developers. This is a special constructor and gets called before the first object is created of the class. The time of execution cannot be determined, but it is definitely before the first object creation - could be at the time of loading the assembly. The syntax of writing the static constructors is also damn simple. Here it is: public class myClass
{
static myClass()
{
// Initialization code goes here.
// Can only access static members here.
}
// Other class methods goes here
}
Notes for Static Constructors:
Ok fine, all the above points are fine, but why is it like that? Let us go step by step here. Firstly, the call to the static method is made by the CLR and not by the object, so we do not need to have the access modifier to it. Secondly, it is going to be called by CLR, who can pass the parameters to it, if required. So we cannot have parameterized static constructor. Thirdly, non-static members in the class are specific to the object instance. So static constructor, if allowed to work on non-static members, will reflect the changes in all the object instances, which is impractical. So static constructor can access only static members of the class. Fourthly, overloading needs the two methods to be different in terms of methods definition, which you cannot do with Static Constructors, so you can have at the most one static constructor in the class. Now, one question raises here, can we have two constructors as: public class myClass
{
static myClass()
{
// Initialization code goes here.
// Can only access static members here.
}
public myClass()
{
// Code for the First myDerivedClass Constructor.
}
// Other class methods goes here
}
This is perfectly valid, though doesn't seem to be in accordance with overloading concepts. But why? Because the time of execution of the two methods are different. One is at the time of loading the assembly and one is at the time of object creation. Constructors FAQs
| ||||||||||||||||||||||||||||