Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to initialize a C# static class before it is actually needed?

Tags:

c#

static

I have a static class with a static constructor that takes some time (10-15 seconds) to execute and fully initialize the class. In order to improve performance, I've decided to enable this static class to be explicitly initialized instead of when it is first needed so that it is ready to go when it actually needs to be used.

My first thought was to create an Initialize() method for the class, but since I already have a static constructor, this method doesn't seem to need to do anything other than be the method to call to explicitly initialize the class without accessing any of its other public methods or properties. Having a method that does nothing directly doesn't seem right to me.

Then I thought I can just move the code from the static constructor into this Initialize() method, but I'd also like the class to be initialized when it is first needed and the Initialize() method wasn't explicitly called.

To summarize, I want the following criteria to be observed:

  • I want to allow the static class to be explicitly initialized (likely by using a public Initialize() method).
  • I don't want to have to access any other public methods or properties on the class when I don't need them, even though this would initialize the static class.
  • If the class has not been explicitly initialized, I still want to initialize it when it is first needed (i.e. when accessing other public methods or properties with the intent of using the functionality or data they provide).
  • This is a helper class and using the Singleton design pattern is not necessary for my purposes.

What would be the proper way to observe the above criteria for a static class written in C#? This can also apply to other programming languages (e.g. Java), but I'm personally interested in a solution written in C#.

like image 946
Bernard Avatar asked Jan 05 '12 19:01

Bernard


2 Answers

I would go with the initialize method (EDIT: See Jon's answer). But if you really just want to use the constructor, you can do this:

var type = typeof (YourType);
System.Runtime.CompilerServices.RuntimeHelpers.RunClassConstructor(type.TypeHandle);

RunClassConstructor allows you to force the class constructor (static constructor) to run if it already hasn't. If it has already run, say because you used a static member of the class, then this has no effect. Running it additional times has no effect.

like image 195
vcsjones Avatar answered Sep 26 '22 06:09

vcsjones


I would probably just go for the Initialize method - and it can do something useful:

  • It can log that you're explicitly trying to initialize the class, with a stack trace
  • It might throw an exception if the class is already initialized via another Initialize call
  • You could possibly (with a bit of effort and reorganization) sort things so that any exceptions caused during initialization were propagated without the TypeInitializationException which you'd normally get.
like image 42
Jon Skeet Avatar answered Sep 22 '22 06:09

Jon Skeet