单件模式+打开窗体+窗体构造函数参数
2014-05-20 10:35
423 查看
利用单件模式避免重复打开窗体,窗体为无参数构造函数模式。
注:该博客中有自动关闭窗体的方法
http://www.cnblogs.com/zfanlong1314/p/3567308.html
为了打开窗体时传入参数,可以改变方法的传递参数,本人修改后代码如下
/// <summary>
/// 泛型实现窗体实例单件化
/// </summary>
/// <typeparam name="T">窗体类</typeparam>
public static class Singleton<T> where T : Form//, new()
{
private static T instance = default(T);
private static readonly object lockHelper = new object();
/// <summary>
/// 获取窗体的唯一实例
/// </summary>
/// <param name="args">构造函数参数</param>
/// <returns></returns>
public static T Instance(object[] args)
{
if (instance == null)
{
lock (lockHelper)
{
if (instance == null)
{
instance = (T)Activator.CreateInstance(typeof(T), args);
//加上实例关闭事件,窗体就会自动回收,即instance=null;
instance.FormClosed += new FormClosedEventHandler(DestroyForm);
}
}
}
return instance;
}
/// <summary>
/// 当窗体关闭时将Instance置空
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private static void DestroyForm(object sender, FormClosedEventArgs e)
{
instance = default(T);
}
这样修改可以避免重复打开窗体,且能传递参数。但是如果一个窗体有多个构造函数时就只能打开一个实例。
搜到如下解决方案,但是对func<T> 方法不熟悉,不知道如何用,待后续研究
http://bbs.csdn.net/topics/360165634
该帖子的最后解决方法是:将你的G_<T>的构造函数中传入一个匿名委托Fun<T>参数,由外部的匿名委托来返回一个对象的实例,这样你就不必关心构造函数是否带参数的情况。代码如下
public class SingletonGenerator<T>
{
private object locker;
private bool initialized = false;
private Func<T> func;
private T instance;
public SingletonGenerator(Func<T> funcParam)
{
initialized = false;
func = funcParam;
locker = new object();
}
public T Value
{
get
{
if (!this.initialized)
{
lock (this.locker)
{
if (!this.initialized)
{
this.instance = this.func();
this.initialized = true;
}
}
}
return this.instance;
}
}
}
注:该博客中有自动关闭窗体的方法
http://www.cnblogs.com/zfanlong1314/p/3567308.html
为了打开窗体时传入参数,可以改变方法的传递参数,本人修改后代码如下
/// <summary>
/// 泛型实现窗体实例单件化
/// </summary>
/// <typeparam name="T">窗体类</typeparam>
public static class Singleton<T> where T : Form//, new()
{
private static T instance = default(T);
private static readonly object lockHelper = new object();
/// <summary>
/// 获取窗体的唯一实例
/// </summary>
/// <param name="args">构造函数参数</param>
/// <returns></returns>
public static T Instance(object[] args)
{
if (instance == null)
{
lock (lockHelper)
{
if (instance == null)
{
instance = (T)Activator.CreateInstance(typeof(T), args);
//加上实例关闭事件,窗体就会自动回收,即instance=null;
instance.FormClosed += new FormClosedEventHandler(DestroyForm);
}
}
}
return instance;
}
/// <summary>
/// 当窗体关闭时将Instance置空
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private static void DestroyForm(object sender, FormClosedEventArgs e)
{
instance = default(T);
}
这样修改可以避免重复打开窗体,且能传递参数。但是如果一个窗体有多个构造函数时就只能打开一个实例。
搜到如下解决方案,但是对func<T> 方法不熟悉,不知道如何用,待后续研究
http://bbs.csdn.net/topics/360165634
该帖子的最后解决方法是:将你的G_<T>的构造函数中传入一个匿名委托Fun<T>参数,由外部的匿名委托来返回一个对象的实例,这样你就不必关心构造函数是否带参数的情况。代码如下
public class SingletonGenerator<T>
{
private object locker;
private bool initialized = false;
private Func<T> func;
private T instance;
public SingletonGenerator(Func<T> funcParam)
{
initialized = false;
func = funcParam;
locker = new object();
}
public T Value
{
get
{
if (!this.initialized)
{
lock (this.locker)
{
if (!this.initialized)
{
this.instance = this.func();
this.initialized = true;
}
}
}
return this.instance;
}
}
}
相关文章推荐
- 在模式窗体中提交而不打开新窗体
- 打开指定大小的模式窗体
- MDI窗体的一些问题及单件模式的应用
- C# 单例模式和窗体的单例打开方法
- 模式窗体提交时不打开新的页面
- 打开showModalDialog模式窗体并提交,且不打开新的IE窗口
- JS打开模式窗体
- 单件模式Singleton来控制窗体被重复或多次打开
- 在打开有模式窗体后还能"显示"无模式窗体
- 在MVVM模式中打开子窗体(Child Window) (转)
- 窗体中有一个图片框,显示一副图片。要求:1)在窗体打开时,动态加载图片;2)设置图片显示模式为根据图片框大小缩放图片;3)图片自己找;4)当鼠标停留在图片框时,显示“**风光”提
- (翻译)在MVVM模式中打开子窗体(Child Window)
- Silverlight:在MVVM模式中打开子窗体(Child Window)
- 在模式窗体中提交而不打开新窗体
- 模式窗体中提交的时候不打开新窗体
- 利用单例模式解决WinForm中子窗体只允许打开一次的问题
- C# 单例模式和窗体的单例打开方法
- 子窗体只能打开一个(单例模式)
- 单实例模式的实现(singleton)----单件
- 关闭模式窗体后,如果该窗体是由父窗体show出来的...