静态泛型类可以有多个单个实例吗?
标准静态类只有一个实例,对吗?像这样:
public static class MyClass
{
public static string MyString { get; set; }
}
public void ExampleMethod(int id)
{
if (id > 0)
MyClass.MyString = id.ToString();
}
在我的程序中,MyClass
代表单个实例,即应用程序作用域。
好的,但是,如果MyClass
是通用的呢?
public static class MyClass<T>
{
public static string MyString { get; set; }
public static T MyT { get; set; }
}
意味着对于指定的每个类型参数,我的应用程序范围将创建一个新实例?或者它会为每个可能的类型参数创建一个单独的实例? (我真的希望它没有)
对于逻辑,它不能仍然是单个实例,因为我可以这样做:
public void ExampleMethod(int id)
{
MyClass<int>.MyT = id;
MyClass<DateTime>.MyT = DateTime.Now;
MyClass<string>.MyT = "Hello, World";
MyClass<DayOfWeek>.MyT = DayOfWeek.Monday;
}
提前致谢所有回复
更新 - Microsoft .Net团队已经使用
无意中,我发现了一个使用静态泛型类的示例,内置于mscorlib
DLL中:
// Decompiled with JetBrains decompiler
// Type: EmptyArray`1
// Assembly: mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
// MVID: 7D59CE68-D0F6-428F-B71C-C8D703E59C19
// Assembly location: C:\Windows\Microsoft.NET\Framework64\v4.0.30319\mscorlib.dll
internal static class EmptyArray<T>
{
public static readonly T[] Value = new T[0];
}
该类的存在意味着应用程序范围将创建一个空数组,如果尚未为给定类型创建(可能数组是内存猎手对象)。
答案 0 :(得分:5)
是的,动态生成泛型类的非泛型版本。这意味着每个静态变量在生成的非泛型版本(是的,另一个Type
)的上下文中是静态的。
要解决此预期行为,您可以在泛型类之外创建一个单例模式类,其中放置所有静态变量,应该在所有版本之间共享。
答案 1 :(得分:3)
实际上,当你的类是静态的时,根本没有它的实例,无论该类是否是通用的。但是你的意思是泛型类的所有实现 - 例如MyClass<int>
,MyClass<string>
等等 - 是完全不同的类型,它们被编译到不同的类并且彼此之间不知道任何东西,他们甚至没有实现相同的基类。