[英]Singleton with Activator.CreateInstance
我有一個實現Singleton設計模式的類。 但是,每當我嘗試使用Activator.CreateInstance(MySingletonType)獲取該類的實例時,只會調用私有構造函數。 除了私有構造函數,還有什么方法可以調用其他方法?
我的課程定義如下:
public class MySingletonClass{
private static volatile MySingletonClassinstance;
private static object syncRoot = new object();
private MySingletonClass()
{
//activator.createInstance() comes here each intantiation.
}
public static MySingletonClassInstance
{
get
{
if (instance == null)
{
lock (syncRoot)
{
if (instance == null)
instance = new MySingletonClass();
}
}
return instance;
}
}
}
實例化如下:
Type assemblyType = Type.GetType(realType + ", " + assemblyName);
IService service = Activator.CreateInstance(assemblyType, true) as IService;
Activator.CreateInstance
除一個極端情況外,始終創建一個新實例。 我建議您可能不想在這里使用Activator
。
但是,如果您別無選擇,那么hacky hack hack就是創建一個從ContextBoundObject
繼承的ContextBoundObject
,並使用ProxyAttribute
的自定義子類對其進行ProxyAttribute
。 在自定義ProxyAttribute
子類中,重寫CreateInstance
以執行所需的任何操作。 這是種邪惡。 但它甚至可以與new Foo()
。
嘿,我不知道為什么要使用反射創建單例類的對象。
單例類的基本目的是它只有一個對象並且具有全局訪問權限。
但是,您可以訪問單例類中的任何方法,例如:
public class MySingletonClass {
private static volatile MySingletonClass instance;
private static object syncRoot = new object();
private MySingletonClass() { }
public static MySingletonClass MySingletonClassInstance {
get {
if (instance == null) {
lock (syncRoot) {
if (instance == null)
instance = new MySingletonClass();
}
}
return instance;
}
}
public void CallMySingleTonClassMethod() { }
}
public class program {
static void Main() {
//calling a
methodMySingletonClass.MySingletonClassInstance
.CallMySingleTonClassMethod();
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.