There is a very easy trick which creates a dictionary-like structure where keys are types.
The structure acts like a Dictionary<Type, T?> where keys are Type objects and values are instances of the corresponding types.
This wonderful structure is as fast as just a variable or array since the “lookup” is only done once by the compiler/JITter and the proper value reference is compiled into your program.
public static class MyDict<T> {
public static T Value { get; set; }
}
You can work with that structure like this:
MyDict<string>.Value = MyDict<int>.Value.ToString();
The problem is that this “dictionary” is global. The only way to create different dictionaries is to create different classes.
How can create a similar (fastest “lookup”, no boxing) non-static structure? (Without code generation.)
Simply said: I want to have multiple Dictionary<Type, object>-like objects without lookup costs, casting and boxing.
Ark-kun is using generics to essentially generate unique types at compile time. With a generic type, any static members are unique to that specific closed generic type. This way it’s processed as fast as a standard static member lookup.
The above usage is equivalent to something like this:
AFAIK, types are “static” (in that you can’t define more than one that way) so I don’t know of a way to cheat around this and maintain the same performance of a statically compiled member lookup.
Your best bet otherwise (I think) is to create a generic instance type that wraps its own dictionary that uses
System.Typefor its keys andSystem.Objectfor its values to which you have to perform boxing/casting when inserting/retrieving values.EDIT: Here’s a simple implementation wrapping a dictionary:
Thinking about it more, it might be possible to achieve a more property-like syntax using an
ExpandoObject(http://msdn.microsoft.com/en-us/library/system.dynamic.expandoobject.aspx) through some tomfoolery, but I feel like this would be pretty abusive and I can only assume terribly prone to runtime errors. (plus it would afford you nothing at compile time)EDITx2: If you really want to have different sets of values, you could nest it within another generic type:
With usage like:
But then the initial type
intandboolin this case become “magical” and without meaning, plus you would need to provide a unique type per distinct set of values you’d like to use. Plus you could not pass it around and modify as an instance variable, rather it’d be statically accessible (so long as you have access to use the typeT). So perhaps you could declare minimally visible types that are named with meaning and use those:Regardless, I think this is quite wacky and I wouldn’t recommend it.