设计模式:使用泛型实现独身模式

使用 C# 2.0 泛型来完成单例模式的重用

  使用 C# 2.0 的泛型,使得实现我所说的"单例提供者"成为可能。这是一个可用来创建单例类实例确不需要为每个特定的类重写单例模式代码的可重用的类。这样分离出单例结构的代码,将有利于保持按单例模式使用类或不按单例模式使用类的灵活性。

public sealed class Singleton
{
 Singleton()
 {}

 public static Singleton Instance
 {
  get
  {
   return SingletonCreator.instance;
  }
 }

 class SingletonCreator
 {
  // Explicit static constructor to tell C# compiler
  // not to mark type as beforefieldinit
  static Nested()
  {}

  internal static readonly Singleton instance = new Singleton();
 }
}

  基于对泛型的了解,你可以发现没有理由不在这段代码里替换类型参数为泛型里典型的'T'。如果这样做,这段代码就变成下面这样。

public class SingletonProvider<T> where T : new()
{
 SingletonProvider() { }

 public static T Instance
 {
  get { return SingletonCreator.instance; }
 }

 class SingletonCreator
 {
  static SingletonCreator() { }
  internal static readonly T instance = new T();
 }
}

  注意在这里使用了泛型的约束。这个约束强制任何类型'T'都必须具有无参数的公共构造函数。这里允许singletonCreator类来实例化类型'T'。

  那么,要怎么样来使用单例提供者呢?为了弄清除如何使用它,我们需要写一个测试类。这个测试类有两个部分。第一部分是一个默认的构造函数,用来设置timestamp变量的值。第二部分是一个公共函数,用来实现用"Debug.WriteLine"来输出timestamp的值。这个测试类的意思就是不论那个线程在任何时候,在单例下调用这个类公共方法,都将返回相同的值。

public class TestClass
{
 private string _createdTimestamp;

 public TestClass ()
 {
  _createdTimestamp = DateTime.Now.ToString();
 }

 public void Write()
 {
  Debug.WriteLine(_createdTimestamp);
 }
}

  这个类就像下面这样使用单例提供者:

SingletonProvider<TestClass>.Instance.Write();

   关注点

  我已经在一个超线程的双处理器上使用100个线程在单态模式下进行了测试。所有线程都返回相同的值,这说明这是一个线程安全的使用泛型来实现的单态模式。 我相信这已经充分说明了泛型怎么帮助你简化代码。

转载于:https://www.cnblogs.com/sadys/archive/2006/05/10/395876.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值