Monday, July 05, 2010

.Net - const Vs readonly

In programming,  some time we used "const", some time "readonly" constants.  Why? Always we should be very cautious when using "const". why?


Here we are, while programming we should always trade off between performance vs flexibility. "const" is faster than "readonly". But "readonly" has more flexibility than "const". There are two types of constants
1) Compile time constants
2) Run time constants


Compile time constants
Compile time constants are replaced with exact value when it compiled. what is it mean? Well. When we declare a variable 


public const int iUserCount = 500;
and when we do some operation like
for (int iCount = 0; iCount < iUserCount; iCount++)


Then x will actually get replaced in the compile time and if you see in the IL using assembler it will be 
for (int iCount = 0; iCount < 500 ; iCount++)
Run Time constants
When we use "readonly", it will not put the actual value instead of reference. Thats why it is slower than Compile time constants. But there is an advantage.


1) With Const we can only declare primitive types and string. But with readonly we can declare all the types.
2) Runtime will be resolved at the runtime


Why we need very cautious about "const".


We should be very cautious about "const" when maintenance come into picture. The reason is, assume you have an assembly "A" where you have declared the
public const int iUserCount = 500; 


And in the Assembly "B" you are using the iUserCount in 
for (int iCount = 0; iCount < iUserCount; iCount++). 
When compiling both, Assembly "B" will have the statement as 
for (int iCount = 0; iCount < 500; iCount++)


Later when you modify the iCount value as 1500 in assembly "A", 
then you have to recompile the assembly "B" also. 
until unless it will have the same 
for (int iCount = 0; iCount < 500 ; iCount++) 
and produce wrong result. So maintenance become nightmare. 
So prefer readonly then const.


Happy programming!!!









No comments: