В общем, размышления в базовом классе могут быть направлены на некоторые хорошие и полезные цели, но у меня есть случай, когда я нахожусь между молотом и наковальней ... Используйте Reflection или выставляйте открытые классы Factory, когда на самом деле должен быть закрытым семантически говоря (то есть не каждый может их использовать). Я полагаю, здесь приведен код:
public abstract class SingletonForm<TThis> : Form
where TThis : SingletonForm<TThis>
{
private static TThis m_singleton;
private static object m_lock = new object();
private static ISingletonFormFactory<TThis> m_factory;
protected SingletonForm() { }
public static TThis Singleton
{
get
{
lock (m_lock)
{
if (m_factory == null)
{
foreach (Type t in typeof(TThis).GetNestedTypes(BindingFlags.NonPublic))
{
foreach (Type i in t.GetInterfaces())
{
if (i == typeof(ISingletonFormFactory<TThis>))
m_factory = (ISingletonFormFactory<TThis>)Activator.CreateInstance(t);
}
}
if (m_factory == null)
throw new InvalidOperationException(string.Format(
CultureInfo.InvariantCulture,
"{0} does not implement a nested ISingletonFormFactory<{0}>.",
typeof(TThis).ToString()));
}
if (m_singleton == null || m_singleton.IsDisposed)
{
m_singleton = m_factory.GetNew();
}
return m_singleton;
}
}
}
}
Теперь этот код работает для меня, но это ужасный клудж и / или действительно плохая идея? Другая опция передает тип Factory в качестве параметра типа, но затем из-за ограничений видимости класс Factory должен быть общедоступным, что означает, что любой может вызывать его для создания экземпляров, когда они не должны быть.