Per my understanding, both instance methods and static methods are treated same by CLR compiler and the IL code is JITted whenever the method is called first time. Today I had a discussion with my colleague and he told me that the static methods are not treated the same way as instance methods. i.e. Static methods are JITted as soon as the assembly is loaded into application domain whereas instance methods are JITted as they are called for the first time.
I am actually confused and do not see a reason as to why the static methods should be eagerly compiled by CLR? I understand about static constructors or finalizer methods of the Critical Finalizer Objects or when constrained execution regions are used. But if some class has a combination of static and instance methods, I am really not sure why all static methods would be JITted as soon as the assembly containing the class would be loaded into memory?
Please help me in understanding this behavior.
Looking at when the methods get JIT compiled using WinDbg/SOS shows that static methods are not compiled prior to calling them.
Consider the following class:
I use the NoInlining option to prevent the compiler from inlining these methods in a release build.
If I run a small app like below and attach the WinDbg I can observe when the methods get JIT compiled.
At the point of attach the method table for
SomeType
looks like this:After the methods have been explicitly invoked it looks like this:
I.e. the methods are not JIT compiled until they are actually invoked.
(For the record this was done on .NET 4.5)
As far as I know static methods are not threated differently from instance methods, maybe your colleague is talking about static constructors that actually are invoked as soon the type is referred in the calling assembly. and thus jitted.
Update For 4.0 ( thanks @JulienLebosquain for pointing )
.NET 4.0 uses a so called Lazy Type Initialization, that basically change the behavior and statics constructor are called just when as soon a static field is acceded the first time.